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XYLOGICS 772 Tape Controller User's Manual 


1.0 


1.1 


Loe 


‘SECTION 1: SPECIFICATIONS 


GENERAL 


The Xylogics Model 772 tape controller couples up to eight 
Pertec-formatted Interface 1/2-inch tape drives to VMEbus! systems. 


USING THIS MANUAL 


Section 1 describes the 772 specifications; Section 2 details how 
to install the controller; Section 3 describes the 772 registers; 
Section 4 describes the IOPBs; and Section 5 describes the 772 
commands. Section 6 describes error processing; Section 7 is a 
programming tutorial; Section 8 explains the 772's_ special 
functions; Section 9 details the 772 theory of operation; and 
Section 10 includes drive interface information. 


ab] iat 
This manual uses the following mnemonics: 
AIO Add IOPB 

AIOP AIO Pending 

AIOR AIO Response Time 

AM Address Modifier 

ASS Auto-streaming Select 

AUD Auto-update 

BHT Black Hole Transfer 

CHEN Chain Enable 

CRIO Clear Remove IOPB 

CRBS Clear Register Busy 

CTYP Controller Type 

DFLT Drive Fault 

DRRDY Drive Ready 

ERRS Error Summary 

FERR Fatal Error 

FIFO First In/First Out Buffer 

H Notation for Hexadecimal Values 
ICS —  YOPB Checksum 

I/O Input/Output 

—IOPB Input/Output Parameter Block 
IRAM Battery Backed-up RAM 

LED Light Emitting Diode 

MMA Maintenance Mode Active 
MM Maintenance Mode 


Ll. VMEbus is a trademark of the VMEbus International Trade Association. 
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1.1.1 


1.2 


1.3 


1.4 


Abbreviations (continued) 


NPRM Non-privileged Register Mode 
PNUM Prom Number 

PRIO Priority IOPB 

RBS Register Busy Semaphore 
RIO Remove IOPB 

RMM Register Maintenance Mode 
ROR Release On Request 

SGM Scatter/Gather Mode 

TDT Throttle Dead Time 

THRO Throttle 

TMOD Transfer Mode 

WPT Write-protect 

64KB 65,536 Bytes 


DESIGN RELIABILITY 


Xylogics implements the following features to minimize the 
likelihood of product failure: 


Design for worst case voltage and temperature. 

Extensive evaluation testing. 

Low parts count through extensive use of custan LSI. 

Buffer parity for continuous error checking. 

Low-stress deSign on all components. | 

All components burned-in. 

One card; resides in backplane or expansion chassis. 
Controller is power-cycled under thermal stress during test. 


O0O00000 0 


PHYSICAL, 
PACKAGING -- The 772 resides on one printed circuit board. 


DIMENSIONS -- The 772 is a 2 by 2 Eurocard standard; it measures 
9.2-inches high by 6.3-inches deep (233.35 mm by 160 mm). The 772 
is identical in form-factor to the standard VME (dual high-dual 
wide) printed circuit board. 


SHIPPING WEIGHT — 3 pounds (1.4 kg). 


CONNECTORS -- There are two 50-pin connectors on the edge of the 
board facing out; they protrude through the optional front panel. 


FRONT PANEL -- Xylogics offers the 772 with an optional front 
panel. 


ENVIRONMENTAL 


The 772 environmental requirements are 0 to 550 C, with a maximum 
relative humidity of 90% (without condensation). Air flow across 
the board must maintain a maximum ate eruee differential of 70 C 
to prevent hot spots. 
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1.5 


ELECTRICAL 
POWER -- The 772 uses 4.2 amperes at +5 volts DC (VDC). 


TOLERANCE -- Voltages must be within plus or minus five percent 
(4.75 to 5.25). 


GROUNDING -- Common earth ground must be established between the 
tape drives and the CPU chassis, backplane, and expansion cabinets. 


SYSTEM RELATED SPECIFICATIONS 


DATA TRANSFER MODES — The 772 transfers data in Word or Longword 
mode. The 772 may use byte transfers to align subsequent transfers 
on word boundaries. 


I/O ADDRESSING CAPABILITY — The 772 decodes byte addresses for its 
on-board registers. 


DATA BUFFERING -- The 772 has a FIFO buffer that is 8k-bytes long 
and incorporates parity error detection. Data can be put into one 
end of the FIFO and simultaneously removed at the other end; there 
are no delays associated with filling and emptying the buffer. 


COMMAND BUFFER -- The 772 reads commands into a separate buffer 
that holds up to fifteen full commands (IOPBs); this minimizes 
processor intervention and optimizes controller decode overhead. 
The 772 also stores up to fifty IOPB addresses. 


STATUS LEDS — The 772 implements two status LEDs. Ll (BSY) 
indicates the controller is active; L2 (ERR) indicates the on-board 
diagnostics did not complete successfully, or a fatal error 
occurred. | 


MULTIPROCESSOR SUPPORT — The 772 has a built-in register control 
semaphore. This flag allows multiple processors to share the 772 
register set. See Section 8.2 for more information. 


SCATTER/GATHER -—- The 772 supports Scatter/Gather Read and Write 
commands. The controller can gather data from various memory 
locations and transfer it to the buffer for use in a Write command; 
it can scatter the data out from the tape drive to the appropriate 
memory locations with a Read command. To execute a scatter/gather, 
software issues a normal Read or Write command along with a DMA 
list that contains a memory address and the number of 16-bit words 
to transfer to/from that location. The smallest granularity of 
scatter/gather is one 16-bit word. 


PRIORITY IOPBs — The 772 executes priority IOPBs over all IOPBs in 
its command buffer, except for the one in process. 


BLACK HOLE TRANSFERS — The 772 may transfer all the DMA data into 
the same bus address without incrementing the address at each DMA. 
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1.7 


SYSTEM RELATED SPECIFICATIONS (continued) 


SOFIWARE SUPPORT -- Sample software driver supplied for use in 
UNIX2 based systems (source included). 


SOFIWARE CONTROL -- Software can program the 772 for use with 
various drive configurations, controller parameters, and controller 
options. 


TAPE DRIVE RELATED SPECIFICATIONS 
TAPE INTERFACE — Pertec-formatted Interface. 


TAPE DATA TRANSFER RATE -——- The 772 supports tape drive transfer 
rates from 20 kilobytes per second (KBS) to 2 megabytes per second 
(MBS). The tape data transfer rate is a function of tape speed, 
density, and in certain cases the tape cache speed. — 


NUMBER OF TAPE DRIVES -——- The 772 supports up to eight tape drives, 
including mixed speeds, densities, and types. 


DRIVE PARAMETER PASS THROUGH -——- The 772 supports any tape drive 
manufacturer's command set via a special command. The 772 allows 
software to directy manipulate the tape command lines with this 
Special command. 


READ/WRITE CONTINUOUS DATA — The 772 can read or write continuous 
Streams of data, up to the the entire tape length, by linking the 
data addresses together with a special command. This feature is 
extremely useful in all applications requiring a large amount of | 
data collection. 


AUTOMATIC STREAMING CONTROL -- To successfully maintain Streaming 
mode, software must provide commands and data to the 772 within the 
tape drive's prescribed reinstruct window. If software does not 
meet this time, and the drive is set for Streaming mode, the drive 
repositions (causing a performance loss). ‘The 772 automatically 
Shifts the tape drive into Non-streaming mode if software does not 
meet the reinstruct window, reducing the performance loss to a 
minimum. If software meets the reinstruct window, the 772 switches 
the drive back into Streaming mode. 


ERROR DETECTION AND RETRY — The 772 allows a great deal of 
flexibility in dealing with errors, depending on the application. 
Available options include multiple error reporting, autamatic retry 
on Read or Write operations, and Ignore Read or Write errors. The 
772 reports the actual number of bytes transferred, file marks 
skipped, records spaced, or retries attempted, during Read, Write, 
and Position operations. 


2. UNIX is a trademark of ATS&T. 
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VMEbus RELATED SPECIFICATIONS 
VME COMPLIANCE NUMBER — IEEE P1014/D1.0. 
TRANSFER MODE -— Direct Memory Access (DMA). 


DMA THROTTLE CONTROL -- Each time the 772 becomes bus master, it 
executes DMA transfers to or from the buffer up to the max throttle 
parameter or the number of bytes/spaces available in the buffer. 


DMA DATA TRANSFER RATE —— The 772 transfers data at a rate of up to 
10 MBS; this rate requires Longword mode transfers and a system 
memory that responds within 200 nanoseconds. 


DMA PROCESSOR -—— The 772 has a custom DMA processor that allows 
dual channel operation (speeding up the DMA by reducing the 
inter-transfer overhead). 


DMA DEAD TIME -— The 772 supports a programmable DMA dead time 
between throttle bursts. This prevents the 772 from taking over 
the bus and allows time for other DMA devices to access the bus. 


DATA TRANSFER LIMIT — Data transfer length, from 1 to 65,536 


bytes. The 772 supports unlimited data transfer lengths via a 


special command. 


BUS COMPATIBILITY — The 772 is compatible with the standard 
VMEbus. 


ADDRESSING CAPABILITY -—— Full 32-bit support. The 772 supports 
Master A32, and Slave Al6, as per the VMEbus Specification. Asa 
slave, the 772 responds to Address Modifiers 29H and 2DH. 


DATA WIDTH -- The 772 supports D16 and D32 as per the VMEbus 
Specification. The 772 transfers data one byte, one word, or one 
byte and one word at a time until the transfer aligns with a word 
or longword boundary. 


RELEASE ON REQUEST — The 772 releases the bus at the request of 
other peripheral devices. 


RELEASE WHEN DONE — # £=The 772 releases the bus after each bus 
access. 


BUS REQUEST LEVELS -—- The 772 supports four bus request levels. 


INTERRUPI PRIORITY -—— Software programmable interrupt level and 
vector. 
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1.9.1 


1.10 


SOFIWARE RELATED SPECIFICATIONS 
CONTROLLER I/O PARAMETER BLOCK (IOPB) LENGTH — 26 bytes. 


CONTROLLER REGISTERS —— Seven 8-bit I/O Registers; byte or word 
addressable. Only eight bits respond during word access. 


DIAGNOSTIC SUPPORT -—- Comprehensive set of stand-alone diagnostics 
written in 'C' are available. 


SOFTWARE INTERFACE — The 772 supports a high level software 
interface that allows system software to use the same method to add 
IOPBs to a chain while the controller is busy or while it is free. 


software Interface 


The software interface includes seven byte-wide registers. Four of 
these bytes comprise the VME Address Register, the fifth byte is 
the Address Modifier Register, the sixth byte is the Control and 
Status Register (CSR), and the last byte is the Fatal Error 
Register (FER). The CSR includes two bits that are very important 
to IOPB processing: Add IOPB (AIO) and Remove IOPB (RIO). 


The IOPB is a block of command and status information; it includes 
the bus address, and the requested operation. The software driver 
sets up the IOPB in user memory, sends the IOPB address to the VME 
Address Registers, and sets AIO. After the 772 receives the IOPB 
address, it resets AIO. The 772 then executes the IOPB and, upon 
completion or error, updates the IOPB status and sets RIO. ‘The VME 
Address Registers point to the complete IOPB; the software driver 
reads the address, and resets RIO. 


Software may add IOPBs to the queue, providing AIO is reset, by 
writing the IOPB address to the address registers, and setting AIO 
(regardless of the 772's busy status). 

PROGRAMMABLE FEATURES 

Oo Software Controlled Interrupts or Polled operations. 

o Software Programmable DMA Parameters. 

© Software Controlled Register Response. 


© Software Controlled Transfer Retry/Correction. 
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2.1 
2.1.1 


2.1.2 


2.1.3 


2.1.4 


SECTION 2: INSTALLING AND TESTING THE 772 


GENERAL 


Section 2 describes how to unpack, configure, install, and test 
your 772 controller. 


UNPACKING AND INSPECTION 


Inspect the Shipping Carton 


Inspect the carton for possible shipping damage. If you determine 
there is damage, do not unpack the unit. Notify Xylogics and the 
freight carrier immediately. 


If no damage is visible, carefully unpack the 772. Save the carton 
and other packing material for possible later use. 


Contents 


The 772 is a single printed circuit board. Optional items include 
a manual and/or software on a floppy diskette, or 1/2-inch magnetic 
tape. 


If any items are missing or damaged, please contact Xylogics at one 
of the following telephone numbers. 


United States: (617) 272-8140 
United Kingdom (Milton Keynes): 44-908-569444 


Handling Precautions 


Observing proper handling precautions minimizes the risk of 
damaging the 772 with electrostatic discharge. When transporting 
the 772, use an antistatic bag, antistatic bin, or the original 
shipping carton and packing material. Personnel handling the 772 
should observe proper grounding methods including, but not limited 
to, wrist bands, heel straps, and antistatic mats. 


The 772 has a non-volatile memory circuit that employs a lithium 
battery (at location F6). Do not expose this device to excessive 
heat (greater than 125° C) as it may ignite or explode. 


Inspect the 772 


Inspect the 772 for socketed parts that may have loosened during 
shipment. Make sure all parts are firmly seated in their sockets. 
If any parts must be reinserted, observe proper orientation. 
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CONFIGURING THE 772 


2.2 


You can configure the 772 with several jumper options. 


following subsections describe these options. 


The 


[ee en a een: = 
ee ee ee 
eS a 


ae, sacpeeicaarne 


(Asng) 47 
(L7 uo peyoe3s/3ines) Z7 


772 - Component Location | 


Figure 2-l. 
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20202 


Base Address Selection 


Jumper block JA controls the base address. Table 2-1 shows how to 
set the jumpers for commonly used base addresses. Inserting a 
jumper makes the 772 respond to a 0 on that address line; removing 
a jumper makes the 772 respond to a1. Connect the jumper between 
Similar pin numbers on each block. (The 772 uses bits 1 through 3 
to determine which register is being accessed.) The 772 is an Al6 
Slave, and responds to address modifier 02DH, and optionally 29H. 


Figure 2-2. Base Address Jumper Block 


Address Bit/ 

Screen Label --> F E D C BA 9 8 7 5 4 
0200 I III I I Of] ee ee ee 
0800 I I Iii O IiIiil I I I I 
EE/0 OO 0 I 0 OO I I OO QO 
EE60* 000 1 0 00 Tf I OO iT 


O = Out; I = In; 


* Standard Factory Configuration 


Table 2-1. Base Address Selection 


Bus Request and Bus Grant Lines 


The 772 uses the Bus Request and Bus Grant lines to become bus 


master. In VMEbus arbitration, there are four Bus Request/Grant 
levels: 0 through 3. The 772 drives one Bus Request line 
according to the jumper scheme you choose. ‘The arbiter drives the 
four Bus Grant In lines: BGOIN* through BG3IN*. If the 772 
receives a Bus Grant, and is not requesting the bus, it passes the 
grant by driving the appropriate Bus Grant Out line: BGOOUT* 
through BG300T*. 
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2.203 


2.24 


Bus Reguest and Bus Grant Lines (continued) 


Select a Bus Request level by jumpering one Bus Request (BRO* 
through BR3*), one Bus Grant In, and one Bus Grant Out line to 
match the selected request level. Jumper the remaining Bus Grant 
In/Out lines so that the incoming signal passes through the board 
(i.e., jumper BGxIN* to BGxOUT*, where x represents the remaining 
Grant levels). | 


For example, Figure 2-3 shows the jumpering scheme for level 0 
(Figure 2-3A shows the jumper blocks as they actually appear on the 
board; 2-3B is labeled for this example): ‘jumper JBl to JB5; then 
jumper JCl to JCS, and JD] to JD5. Jumper the remaining Grant 
levels from JC6 to JD2, JC7 to JD3, and JC8 to JD4. Factory 
configuration: Bus Request Level 3. 


NOTE 


Some VME processors only support Bus Request Level 3. 


BR OUT IN 
Ue BG — 
Figure 2-3A. Actual Board Layout Figure 2-3B. Sample Jumpering Scheme 


Figure 2-3. Jumpering Bus Request and Bus Grant Levels 


If you are using the 772 in parallel arbitration, and the Bus Grant 
Out lines must be isolated from the next slot's Bus Grant In lines, 
remove all jumpers between JC 5-8 and JD 1-4 (see Figure 2-3B). 


Light Emitti Di j 


The 772 has two light emitting diodes (LEDs). Ll (BSY) is the Busy 
LED (it is located closest to the printed circuit board). L2 (ERR) 
is the Error LED (it straddles Ll). When L2 is on, SYSFAIL is 
asserted on the VMEbus. 
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2.4 


2.9 


20del 


22562 


Rev. B 


Location Part Number Type 


B8 180-002-138 EPROM 
D2 181-001-021 PAL 
L3 181-001-019 PAL: 
E2 181-001-020 PAL 


Table 2-2. PROM/PAL Part Number and Location 


BOARD LABELS / REVISION CONTRCL 


All Xylogics controllers use various revision control labels. This 
information is important when discussing configuration issues with 
OEM Engineering. Please familiarize yourself with your board 
revision levels before contacting us. 


772-001-01 


| tf 
Product, lL | 
Configuration__|  |___Revision Level 


Figure 2-4. Sample Part Number 


PREPARING THE COMPUTER SYSTEM 


The backplane of your system must provide a VMEbus slot for the 
772. The slot must be capable of handling a bus master, and the 
power source must handle the power consumption of the entire 
system, including the 772. 


Backplane Jumpers 
Remove any jumpers that short, or cause the Interrupt Acknowledge 


(IACK IN/OUT) and DMA Grants (BG 0-3 IN/OUT) to bypass the slot in 
which you are installing the 772. 


Card Cage Slot 
The card cage must have a slot at the proper DMA priority available 


for the 772. The 772 uses DMA to transfer data and IOPBs. 
Placement of the 772 in the DMA priority chain may be critical. 
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2.53 


2.6 


2.6.1 


2/7 
2-71 


Card Cage Slot (continued) 


The amount of bus bandwidth it uses will be high at times; this may 
affect other boards in the system. Likewise, other boards may not 
allow enough time for the 772 to DMA enough data to keep up with 
the tape; consider this when choosing a slot. If the 772 does not 
get a high enough priority, then its DMA falls behind what the tape 
requires, and the tape repositions. If the 772 priority is high, 
it gets enough DMA time, but other boards having insufficient 
buffers may starve from lack of DMA time. The priorities must be 
balanced for your system to work properly. 


Power Considerations 


The 772 affects the power consumption of the entire computer 
system. The 772 uses 4.2 amperes of +5 volts DC (4.75 to 5.25 
volts) for all logic. Be sure the power supply can handle the 
entire power load. Readjust the voltages AFTER plugging in the 
772. A power supply that is just adequate may cause intermittent 
and unusual problems due to noise generated by occasionally going 
into overcurrent protection. 


PREPARING THE TAPE DRIVE 


Unpack and configure the drive for use with the 772. ‘This may 
entail setting up such parameters as formatter address, unit 
select, remote density select, ramp delay, etc. Consult the drive 
manual for the exact method for configuring your drive. 


Drive Unit Select 


A switch on the front of the drive, or switches on one of the 
drives internal circuit cards, selects the drive unit number and 
formatter address. The 772 accesses drives with unit numbers 
ranging from 0 through 3, and formatter addresses from 0 through 1 
(allowing addressing up to eight drives). Pertec~formatted 
interface drives require one formatter card (embedded in one drive) 
for every four tape drives. 


INSTALL AND CABLE THE 772 
install the 7/2 


Double check the jumpering. Place the 772 into the computer card 
cage; make sure it is firmly seated. Be careful not to dislodge 
any socketed ICs. Situate the tape drive and connect it to its 
power source. 
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2.7.21 


Ze e2e2 


2.8 


2.8.1 


2.8.2 


Cable the Subsystem 


A cable set consists of two identical 50-pin flat ribbon cables 
that conform to the Pertec-formatted interface standard; these 
cables are typically 15- to 25-feet long. Xylogics does not 
provide the cables; they can usually be purchased from the drive 
vendor. Observe the Jl (Write Data)/J2 (Read Data) connector 
markings on the 772 when cabling the controller to the mating tape 
drive connector. All drives do not label connectors the same; you 
may have to read the drive manual to determine how to connect Jl 
and J2. Also, you must observe the pin "1" markings on the cable 
connector for proper orientation on both the drive and the 772. 
Using pull tabs on the cable connectors greatly reduces connector 
damage. (Only cable one tape drive for the initial system check. 
You can connect additional tape drives later.) 


Mechanical Restraint 
Xylogics recommends mechanically restraining both cables at each 


end to prevent accidental disconnection. 


Tape Drive Grounds 


Install a ground braid wire between the ground terminal on the 


tape drive(s) and the computer system ground. 


INITIAL TESTS 


This section relies upon your familiarity with your computer 
system's monitor and diagnostics. 


Many tape drive manufacturers offer both on-line and off-line 
diagnostic capability. Xylogics recommends initially running the 
full off-line drive diagnostic before trying to access the drive 
via the 772. ‘This helps prove that the drive is functional. Each 
manufacturer's diagnostic is different; consult your drive manual. 


Power-up and Self Test 


The 772 initiates a self test upon power-up. The Error LED (L2) 
lights for a moment, and then goes off. If L2 remains on, and the 
Fatal Error Register indicates an IRAM checksum error, then you 
need to load good parameters into the IRAM. Otherwise, if L2 
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2.8.2 


2.8.3 


2.9 


2.10 


Power-up and Self Test (continued) 


remains on, the board is not functioning properly (the Fatal Error 
Register may indicate the nature of the problem). When L2 is on, 
SYSFAIL is asserted on the VMEbus. Contact Xylogics for further 
assistance. 


NOTE 


Check the power supply voltage to ensure 
it is within limits (4.75 to 5.25 volts). 


Drive On-line 


Load a tape reel, press the load and on-line switches, and wait 
for the on-line indicator to light. Execute a Read Drive 
Parameters command to ensure the drive issues the correct status 
(see Section 4.1). If the IOPB completes without error, Byte 3 
should at least have the BOT, DRRDY, and ONLIN bits set. If any 
of the three are not set, it is possible that the cables are 
improperly connected or the tape reel is improperly mounted. If 
this is not the case, then there is a possible hardware error on 
either the drive or the 772. If the problem persists, check the 
tape drive for functionality with an off-line diagnostic or 
tester. 


DIAGNOSTICS 
When you run your diagnostics: 


© Run a full pass of the diagnostics. 
o Cable and test any additional drives (see Section 2.10). 


CABLING MULTIPLE DRIVES 


Connect the first drive in the chain directly to the 772; connect 
additional drives together, starting with the first drive. For 
example, the 772 connects to Drive 0; Drive 0 to Drive 1; Drivel 
to Drive 2, etc. (see Figure 2-5). Be sure to maintain continuity 
of pin 1 and J1/J2 connectors between drives. Some drives have 
extra connectors on the I/O card for daisy-chaining cables. For 
drives that do not have extra connections, you must construct a 
cable with a third connector (see Figure 2-6). 
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2.10.1 Unit Select 


If you are daisy-chaining drives, assign each drive a unique Unit 
Select number. The 772 accesses drives with unit numbers from 0 
through 3, and formatter addresses from 0 through l. 


F |} TAPE O TAPE 1 TAPE 2 TAPE 3 
M 
S PM {7}. J1 C) C) OC) C) 
2 HS HSS 


Figure 2-5, Cabling Multiple Drives 


Figure 2-6. Daisy~chain Cable 
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3.0 


3.1 


3.2 


_ SECTION 3: THE 772 REGISTERS 


GENERAL 


The 772 programming interface uses seven, one-byte long, I/O 
registers. The bus address jumpers define the base address of the 
register set. Table 3-l lists the registers along with the address 
offset from the base address. The 772 responds to 16-bit words, 
but only 8 bits are valid. 


The registers have one function when read, and another when 
written. The following subsections detail their definitions. 


Register Offset 
IOPB Address Byte 0 (Least Significant Byte) 
IOPB Address Byte 1 

IOPB Address Byte 2 

IOPB Address Byte 3 (Most Significant Byte) 
IOPB Address Modifier 


Control and Status Register 
Fatal Error Register 


UW ONO W Ee 


Table 3-1. Register Offsets 


NOTE 


The 772 supports VME short addressing for I/O devices 
(Al6). It responds to Address Modifiers 29H and 2DH. 
For more information see the VMEbus Specification. : 


IOPB ADDRESS REGISTERS 


The first four registers define the 32-bit address of an IOPB or 
IOPB chain. When these registers are written, the 772 interprets 
it as the address of the IOPB or IOPB chain to be executed. When 
read, and Remove IOPB (RIO) is set, the registers point to the IOPB 
or IOPB chain just completed by the 772. 


The protocol for reading and writing this address register is 


defined by the use of Add IOPB (AIO) and Remove IOPB (RIO) in the 
Control and Status Register (see Section 3.3). 
IOPB ADDRESS MODIFIER / PRIORITY IOPB REGISTER 


This register defines the Address modifier of the IOPB address. 
The VMEbus Specification defines the address modifiers. 
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3.2 


3.3 


3.3.1 


IOPB ADDRESS MODIFIER / PRIORITY IOPB REGISTER (continued) 


There is no default value for this register; it must be written 
each time the IOPB Address Registers are written. This register 
also specifies whether an IOPB has priority over the current set of 
IOPBS in the 772 command queue. Section 3.3 defines the protocol 
for reading and writing this register. 


PRIORITY IOPB REGISTER 


[71615 7/4/3 12 71 [0 | 


PRIORITY IOPB REQUEST. ..._—s—s—i Cd | | | | | | 
RESERVED. —“‘“(‘(#“;RK(N(NNNN’N’N’NNL | | | | | | 
ADDRESS MODIFIER... tC—“‘“‘(‘(‘(‘(;C(CdUUUU CL 


Bit M ; Definit: 


7 PRIO PRIORITY IOPB REQUEST - When set, the IOPB, or 
IOPB chain, precedes all others (except the one 
in process) in the command queue. 


6 RESERVED. 


5-0 AM ADDRESS MODIFIER - See the VMEbus Specification. 


CONTROL AND STATUS REGISTER 


When written, this register provides the host with control of the 
772 Operation; when read, it provides the host with 772 status 
information. Sections 3.3.1 and 3.3.2 define the bits in this 
register when read or written. 


Control Register (Write) 
CONTROL REGISTER (WRITE) 


{71/615 /4]/3 12/11/04 

REGISTER MAINTENANCE MODE si | | | | | | | 
RESERVED ee | | 
ENABLE MAINTENANCE MODE are | 
ee a ee Se ee ee 
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Be ra! Control Register (Write) (continued) 


Bit Mnemonic 
7 RMM 

6 

5 MM 

4 

3 CRST 

2 AIO 

1 CRIO 
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Definit: 


RHGISTER MAINTENANCE MODE - When RMM and MM are 
set, the values previously written in all the 
registers (except the CSR) are echoed back. 


RESERVED. 


ENABLE MAINTENANCE MODE - Setting MM and AIO 
places the 772 in Maintenance mode. This mode 
Supports a different Register protocol and is 
used aS a diagnostic tool. Section 8 outlines 
the Maintenance mode. 


RESERVED. 


CONTROLLER RESET - CRST signals the 772 micro- 
processor to perform a "soft" reset; it stops the 
DMA, and cancels any IOPBs in the queue. When 
the Controller Reset completes, the 772 resets 
the CSR to zero. A Controller Reset does not 
initiate a Power-up Self Test. 


ADD IOPB -— The host sets AIO to indicate that the 
772 should execute the IOPB (chain) at the 
address pointed to by the IOPB Address and 
Address Modifier Registers. As soon as the host 
asserts AIO, the 772 asserts AIO Pending (AIOP) 
in the Status Register (indicating the 772 has 
received AIO, but has not yet processed the new 
Chain address). AIOP is negated in the Status 
Register after the 772 internally stores the new 
Chain address. The 772 can store up to 50 IOPB 
addresses in this manner. Reasserting AIO if 
AIOP is asserted in the Status Register violates 
the register protocol. 


CLEAR RIO -— The host sets CRIO to clear RIO in 
the Status Register. Typically, the host sets 
CRIO after it reads the address of a completed 
IOPB chain from the IOPB Address and Modifier 
Registers. Clearing RIO enables the 772 to 
update the IOPB Address and Modifier Registers 
with the address and address modifier of a newly 
completed IOPB chain. Clearing RIO if RIO is not 
asserted in the Status Register violates the 
register protocol. | 
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3.3.1 Control Register (Write) (continued) 


Bit Mnemonic 
0 CRBS 


Definiti 


CLEAR RBS - The host sets CRBS to clear RBS in 
the Status Register. Clearing RBS releases the 
registers for use by another host (see Section 
8.2). (CRBS is only relevant in a multiprocessor 
environment. ) 


3.3.2 Status Register (Read) 


BUSY 
FATAL ERROR 


‘MAINTENANCE MODE ACTIVE _.. 


RESERVED 


CONTROLLER RESET ACTIVE 


AIO PENDING 
REMOVE IOPB 


REGISTER BUSY SEMAPHORE 


Bit Mnemonic 
7 BUSY 


Rev. B. August 15, 1987 


STATUS REGISTER (READ) 


[71615 /47]3 |]2];1]/0 | 


Def init: 


BUSY - The 772 is executing IOPBs. The 772 sets 
BUSY when it clears AIOP to acknowledge the first 
IOPB address; it clears BUSY after completing all 
the IOPBs with no new ones pending (within 500 
microseconds of the host clearing RIO on the last 
IOPB). ‘The 772 redefines this bit in Maintenance 
mode (see Section 8.1). 
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3.3.2 Status Register (Read) (continued) 


Bit M Definit: 


6 FERR 
5 MMA 
4 

3 RSTA 
2 AIOP 
1 RIO 
0 RBS 
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FATAL ERROR -— The 772 detected a fatal hardware 
error (a fatal error asserts SYSFAIL). A 
Controller Reset clears this bit. The Fatal 
Error Register contains more specific 
information. The 772 asserts FERR under the 
following conditions: — 


(1) Maintenance Mode Test Failure; 

(2) Power-up Self Test Failure; 

(3) IOPB Checksum Miscompare; 

(4) IOPB DMA Fatal; 

(5) IOPB Address Alignment Error; 

(6) Firmware Error; 

(7) Cable Test Failure; 

(8) Illegal Maintenance Mode Test Number; and 
(9) ACFAIL Asserted. 


MAINTENANCE MODE ACTIVE - When set, the 772 is in 
Maintenance mode (see Section 8). 


RESERVED. 


CONTROLLER RESET ACTIVE - The host set CRST in 
the Control Register and the 772 is resetting. 


AIO PENDING - When set, AIO has been set in the 
Control Register, but the 772 #£=/has_ not 
acknowledged its receipt. When clear, AIO may be 
set again. 


REMOVE IOPB —- The 772 completed an IOPB (chain), 
and has made the address available in the IOPB 
Address and Address Modifier Registers. 


After the host reads the address and modifier, it 
must clear RIO by writing CRIO in the Control 
Register. 


REGISTER BUSY SEMAPHORE - RBS allows multiple 
hosts to share access to the 772 registers with- 
out simultaneous access (see Section 8). (RBS is 
only relevant in a multiprocessor envirorment. ) 
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3.4 FATAL ERROR REGISTER 


If a fatal error 


occurs, the 772 returns the appropriate Completion 


Code in this register. Table 3-2 lists the fatal error codes; 
Section 6.4 describes them. 


Cod r oti 


TRAM Checksum Failure 

Power-up Self Test 

IOPB Checksum Miscompare 

IOPB DMA Fatal 

IOPB Address Alignment Error 
Firmware Error 

Cable Test Failure 

Illegal Maintenance Mode Test Number 
ACFAIL Asserted 


Table 3-2. Fatal Error Codes 
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SECTION 4: IOPB DESCRIPTION 


4.0 GENERAL 
This section describes the 772 Input/Output Parameter Block (IOPB) ; 


it begins with the standard IOPB for most data transfer commands 
and follows with variations of the IOPB. 


4.1 STANDARD IOPB 


The 772 uses the standard IOPB for data transfer commands and some 
general purpose commands. 


STANDARD 772 IOPB 


ee CE ae ee a 


. 
; 


OS a 0a 
06 
07 INTERRUPT VECTOR 


1JOPB CHECKSUM HIGH 
lOPB CHECKSUM LOW 


> 
oO 
+ 
Cc 
> 
c~ 
Oo 
O 
Cc 
= 
=| 
_ 
oO 
<= 


| 
| 
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4.1.1 IOPB Byte 0 (Command) 


[71/615 ]/413 /2]71]/0 | 


7 ERRS 
6 DONE 
s) CHEN 
4 SGM 

3-0 COMM 
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ERROR SUMMARY - ERRS is only valid if DONE is 
set. If ERRS is clear, the 772 successfully 
completed the IOPB. If ERRS is set, a hard error 
occurred during IOPB processing. 


NOTE 


Clear DONE and ERRS before executing 
an IOPB. 


DONE - When set, the JIOPB is complete; if 
chained, software may remove the IOPB from the 
chain and reuse it. 


CHAIN ENABLE -— When set, the Next IOPB Address 
Modifier and Next IOPB Address point to the next 
chained IOPB. When clear, this IOPB is not 
chained to another IOPB. If CHEN and IEC are 
set, the 772 returns the whole chain with one 
RIO; if CHEN is set and IEC is clear, the 772 
returns one IOPB at a time. 


SCATTER/GATHER MODE - When set, the JIOPB is 
either a scatter (read) or a gather (write) tape 
transfer; a linked list describes the number of 
16-bit words and to what address the 772 
transfers each section of the data. The link 
address modifier and the link address specify the 
link list location. .- When clear, this IOPB 
specifies the data transfer address; the data is 
transferred to/from contiguous memory. SGM is 


only valid for standard reads and writes. 


COMMAND - See Table 4-2. 
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4.1.2 


4.1.3 


IOPB Byte 1 (Status Byte 1) 


After the 772 executes the JIOPB, it sets DONE and posts a 
Completion Code in this byte (the 772 always updates this byte, 
regardless of AUD's status). Completion Codes are only valid if 
DONE is set. The Completion Code contains the highest error code 
in the error code hierarchy. For tape related errors, the 772 
reports the same status, or a lower error code, in Status Bytes 2 
and 3. Section 6 details each error code and its recommended 
recovery procedure. 


IOPB Byte 2 (Status Byte 2) 
IOPB Byte 2 is a Tape Status byte; it is only valid if DONE is set. 


HARD TAPE ERROR..—“ ( wwmCLCCLCLCUmdTlC(idsi‘<é‘éiLCSOC*SCQQCSC*é*C; 
CORRECTED TAPE ERROR | | | 
RECORD LENGTH SHORT sii OC 
RECORD LENGTH LONG _| | 
FILE MARK DETECTED | 
PHASE ENCODED ID BURST 

END OF TAPE 

WRITE-PROTECT 


Bit M ; tot 


7 HER HARD TAPE ERROR - The 772 sets HER when a hard 
tape error occurs. 


6 CER CORRECTED ERROR - The 772 sets CER when the 
tape drive indicates it corrected a media flaw. 

5 RLS RECORD LENGTH SHORT - The 772 sets RLS when it 
detects a Record Length Short error during a 
Read command. 

4 RLL RECORD LENGTH LONG - The 772 sets RLL when it 
detects a Record Length Long error during a 
Read command. 

3 FMK FILE MARK DETECTED -— The 772 sets FMK when it 


detects a file mark during a Read or File Mark 
Search command, or when it successfully writes 
a file mark. 


2 PEID PHASE ENCODED ID BURST - The 772 sets PEID when 
it detects the phase encoded identification 
burst (1600 BPI). 
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4.1.3 JOPB Byte 2 (Status Byte 2) (continued) 


Bit Mnemonic 
1 EOT 


END OF TAPE - The 772 sets EOT when it detects 
the End Of Tape marker. The 772 latches EOT to 
ensure it is detected. 


WRITE-PROTECE - When set, the tape reel is 
write—protected. 7 


4.1.4 IOPB Byte 3 (Status Byte 3) 
IOPB Byte 3 is a Tape Status byte; it is only valid if DONE is set. 


GCR/NRZ ID San eee ee eed 


HIGH SPEED MODE 
BEGINNING OF TAPE 


7 GC/NR 
6 HISD 
5 BOT 

4 REW 

3 DBSY 
2 FBSY 
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I716;1514/3 12/110] 


, wotj 


GCR/NRZ - When set, this bit indicates one of two 
tape densities. The tape is GCR (6250 BPI) if 
this bit and PEID (bit 2 of Byte 2) are set. The 
tape is NRZ (800 BPI) if PEID is not set when 
GC/NRZ is set. 


HIGH SPEED MODE - When set, the drive is in High 
Speed mode. 


BEGINNING OF TAPE - When set, the tape is 
positioned at the Beginning of Tape marker. 


_ REWIND - When set, the drive is rewinding. 


DRIVE BUSY - When set, the drive is busy with a 
command or data transfer. 


FORMATTER BUSY - When set, the tape drive 
formatter is busy. | 
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4.1.4 LOPB Byte 3 (Status Byte 3) (continued) 


1 DRRDY DRIVE READY - When set, the tape drive is ready 
to accept commands from the 772. 


0 ONLIN ON-LINE - When set, a tape reel is loaded and the 
tape drive is on-line. 


4.1.5  JOPB Byte 4 (Subfunction) 


IOPB Byte 4 is the Subfunction byte. Subfunction Codes follow a 
convention that indicates whether the code is generic to all VME 
controllers, generic to a group of controllers (i.e., 772, 712, 
751, etc.), or specific to a particular controller (see Table 4-1). 


The 772 combines standard Command Codes with Subfunction Codes to 
execute commands. Table 4-2 lists the 772 Command and Subfunction 


Codes. 
Class Subfunction Codes (Hex) 
Generic to All 00-1F 
Generic Tape 20-3F 
772-Specific 40-5F 
Reserved 60-7F 
Generic Disk 80-9F 
751-Specific AO-AF 
712-Specific BO-BF 
Reserved CO-—FF 
Table 4-1. Subfunction Code Classes 
Code Command Subfunction Description 
0 NOP 00 No Operation 
1 WRITE 00 Write 
2 READ 00 Read 


Table 4-2. Command/Subfunction Codes 
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4.1.5 IOPB Byte 4 (Subfunction) (continued) 


3 POSITION 20 Space Record Forward 
21 Space Record Reverse 
40 File Mark Search Forward 
4l File Mark Search Reverse 
42 Mult. File Mark Search Frwd. 
4 DRIVE RESET 00 Drive Reset 
20 Load On-line 
21 Rewind 
22 Unload/O£f—-line 
5 WRITE PARAMETERS 00 Write Controller Parameters 
20 Write Drive Parameters 
6 READ PARAMETERS 00 Read Controller Parameters 
20 Read Drive Parameters 
40 Read Sense Bytes 
41 Read Extended Sense Bytes 
7 EXTENDED WRITE 20 Write File Mark 
21 Erase 
40 Write Continuous 
8 EXTENDED READ 40 Read Continuous 
9 DIAGNOSTICS 00 Self Test 
40 Loopback Test 
Al Security Erase 
A ABORT 00 Abort Command 
B SET DRV PRMTRS 40 Drive NOP 
4l Reserved 
42 Set Low Density 
43 Set High Density 
44 Set 800 BPI 
45 Set 1600 BPI 
46 Set 3200 BPI 
47 Set 6250 BPI 
48 Set Low Speed And Normal Gap 
49 Set High Speed And Normal Gap 
4A Set Low Speed And Long Gap 
4B Set High Speed And Long Gap 
C CMD PASS | 40 Command Pass Through To Drive 
D-F RESERVED XX 


Table 4-2. Command/Subfunction Codes (continued) 
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4.1.6 IOPB Byte 5 (Unit) 


l71/6/5]4 73/2/11 ]0 | 


RESERVED petticoat Eh | 
BLACK HOLE TRANSFER Senne | | 
RESERVED ee | | 

| 


Bit M . L ‘pti 
7-5 RESERVED. 


4 BHT BLACK HOLE TRANSFER - When set, the 772 does not 
increment the bus address during a data transfer; 
IOPB transfers occur normally. When clear, the 
772 does increment the bus address. 


3 RESERVED. 


2-0 UNIT UNIT NUMBER - These bits specify the tape drive 
Unit Number for the operation. Bits 0 and 1 are 
the Unit Selects for each formatter. Bit 2 
selects one of two possible formatters. 


4.1.7 IJOPB Byte 6 (Interrupt Level) 


1716/5 7;,4]/3]12]1 {0 | 
LINK LIST LENGTH —“( CUT | | | 
INTERRUPT LEVEL ee eRe (eee: ee 


Bit M ; , a 
7-3 LiL LINK LIST LENGTH —- These bits specify the length 
of a linked list for Scatter/Gather commands. 


Each element refers to an §8-byte block in the 
linked list. See Section 8.4.2. 


2-0 INT INTERRUPT LEVEL —- The 772 uses the value of these 
bits as the VMEbus’ interrupt level after 
completing the IOPB. ‘The 772 will not interrupt 
if bits 0 through 2 are clear. 
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4.1.8 


4.1.9 


4.1.10 


4.1.11 


4.1.12 


JOPB Byte 7 (Interrupt Vector) 


IOPB Byte 7 determines the interrupt vector that the 772 uses upon 
command completion if interrupts are enabled. This byte is not 
valid if the interrupt level is zero. 


JOPB Bytes 8 and 9 (Count) 


IOPB Byte 8 is Requested Count High; Byte 9 is Requested Count Low. 
These bytes specify the number of bytes to be transferred in a 
Gata transfer, the number of records to skip, the number of file 
Marks to search, or the number of file marks to write. The max- 
imum byte count is 65,536 (a 0 in the count field equals 65,536); 
the extended read/write commands must be used for larger records. 
The maximum count for Skip Records or File Mark Search is 65,535; 
the 772 reports an error if you issue a count of zero for these 
commands. 


NOTE 


Depending on the command, Bytes 8 through 13 have different 
definitions (see Sections 4.2 through 4.4). 


IOPB Byte A (Last Error) 


If the Read/Write Retry or Ignore Read/Write feature is enabled, 
IOPB Byte A indicates the code of the last recovered or ignored 
error for this IOPB. The codes are the same as those normally 
written in the Completion Code in Byte 1 (see Section 4.3). 


IOPB Byte B (Error Count) 


Depending on which feature is enabled, IOPB Byte B indicates the 
number of retries that were necessary to recover an error, or the 
the number of ignored errors that occurred. 


IOPB Bytes C and D (Actual Count) 


IOPB Byte C is Actual Count High; Byte D is Actual Count Low. 
These bytes indicate the actual number of bytes transferred in a 
successful completion, or in a Record Length Short error condition. 
The 772 also posts the actual count done after Position commands 
such as File Mark Search and Space Record. 
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4.1.13 JOPB Byte E (Data Address Modifier) 


RESERVED 


I7167;5 41312 ]1 [0 | 


DATA OR LINK ADDRESS MODIFIER..._—s—“ wd 


7-6 RESERVED. 


5-0 DATA OR LINK ADDRESS MODIFIER - If SGM is set, these bits 
specify the Link List Address Modifier; if SGM is clear, the 
field specifies the Data Address Modifier. The 772 uses 
these modifiers to complete the address (typically, they are 
the same as the modifier used for the IOPB addresses). 


4.1.14 JOPB Byte F (Next IOPB Address Modifier) 


PRIORITY IOPB 
RESERVED 


[71615 7/4/13 12/1 [0 | 


NEXT IOPB ADDRESS MODIFIER.“ ( eC 


Bit M . ‘oti 


7 PRIO 
6 
5-0 NIOFB 
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PRIORITY IOPB — PRIO has the same function as PRIO 
in the Priority IOPB Register. If PRIO and AIO 
are set, setting this bit causes the IOPB to 
precede all others in the command queue (except 
for the IOPB in process). 


RESERVED. 
NEXT IOPB ADDRESS MODIFIER - The Next IOPB Address 
Modifier, along with the Next IOPB Address, point 


to the next IOPB in the chain. (This address 
should match the address in the AM Register.) 
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4.1.15 JOPB Bytes 10 Through 13 (DMA Data Address) 


IOPB Bytes 10 through 13 are the Data or Link List Address 
pointers. IOPB Byte 10 is Data or Link Address High; Byte 13 is 
Data or Link Address Low. If SGM is set, this address points to 
the linked list; if SGM is clear, it points to the data address. 
The 772 uses these bytes with the Data or Link List Address 
Modifiers to determine the data or link list address. 


NOTE 


The link list address must be on a 16-bit word boundary. 


4.1.16 JOPB Bytes 14 Through 17 (Next IOPB Address) 


IOPB Bytes 14 through 17 are the Next IOPB Address pointers. IOPB 
Byte 14 is Next IOPB Address High; Byte 17 is Next IOPB Address 
Low. If CHEN is set in Byte 0, the 772 uses Bytes 14 through 17 
with the Next IOPB Address Modifier to point to the next IOPB in 
the chain. 


NOTE 


The Next IOPB address must be on a 16-bit word boundary. 
This address is the same as the address loaded directly 
into the register; calculate it in the same manner. 


4.1.17 JOPB Bytes 18 and 19 (IOPB Checksum) 


IOPB Byte 18 is IOPB Checksum High; Byte 19 is IOPB Checksum Low. 
The IOPB Checksum bit (ICS) must be set with a Controller 
Parameters command for the 772 to verify checksums. The 772 
calculates the checksum by adding Bytes 0 through 7; it returns the 
checksum with any IOPB that errors, or if AUD is set. If AUD is 
Clear, the 772 does not return the Checksum bytes for successfully 
completed IOPBs. 


NOTE 


The Write Controller Parameters command must have a 
valid checksum value if you are setting ICS. 
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4.2 CONTROLLER PARAMETERS IOPB 


the 
This IOPB sets various controller parameters. The 772 uses 
standard IOPB, but redefines bits in Bytes 8 through E, and 10 


through 13. 


CONTROLLER PARAMETERS 


eee ee oe ae a ee oe 


THROTTLE 
EPROM RELEASE LEVEL 
: CONTROLLER TYPE | 


ro} | oO | ~——NEXTIOPB ADDRESS MODIFIER] 
re: See: 


NEXT 1OPB ADDRESS HIGH 


I | NEXT IOPB ADDRESS | 
NEXT [OPB ADDRESS 


NEXT |OPB ADDRESS LOW | 


l\OPB CHECKSUM HIGH 
- } /0PB CHECKSUM LOW 
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4.2.1 JOPB Byte 8 (Controller Parameters A) 


AUTO-UPDATE 
TRANSFER MODE 
RESERVED 

IOPB CHECKSUM 


ENABLE DMA TIMEOUT 
NON-PRIVILEGED REGISTER MODE 
AIO RESPONSE TIME 


[71615 74/3 12/110 | 
ee ee es ee ee 

f ~— ~— -— | td 
Lo ff — - tot 
If - -— tT ot 
Lo | tf 
| | | 
lest 


Bit M , tot 


7 AUD 
6  IMOD 
5 

4 ‘Ics 
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AUTO-UPDATE — When set, the 772 updates the IOPB 
to the transfer's ending parameters; it updates 
all possible bytes in the IOPB. If an error 
occurs, the 772 updates the IOPB regardless of 
AUD's status. When clear, the 772 updates Bytes 0 
through 3 upon successful command completion. 
Xylogics recommends setting AUD. Commands that 
return information (parameters, etc.) update the 
IOPB regardless of AUD's status. 


TRANSFER MODE - When set, the 772 executes 
transfers in Longword mode. When clear, it 
executes transfers in Word mode. (The 772 always 
transfers IOPBs in Word mode.) If a transfer 
starts on an improper address boundary, the 772 
first transfers a byte, and/or a word, as 
necessary to align boundaries, and continues the 
transfer in the selected mode. The 772 may end the 
transfer with a byte and/or word, if necessary. 


RESERVED. 


IOPB CHECKSUM - When set, the 772 reads the IOPB 
and compares the checksum it generated during the 
read with the checksum the software driver 
appended to the IOPB. The 772 reports a fatal 
error in the CSR if the compare fails; it updates 
the Checksum bytes if the IOPB errors (non-fatal). 
The 772 also updates the Checksum bytes in any 
IOPB if AUD is set. 


. NOTE 
Since this feature adds 50 microseconds 


to each transfer, it effects the 75l's 
performance. 
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4.2.1 IOPB Byte 8 (Controller Parameters A) (continued) 


Bit Mnemonic 
3 EDT 
2 NPRM 


1-0 AIOR 


r oti 


ENABLE DMA TIMEOUT -— When set, the 772 enables a 
DMA bus error timer. When clear, the 772 relies 
on an external VMEbus transfer timer. 


NON-PRIVILEGED REGISTER MODE - When set, the 772 
responds to Address Modifiers 2DH and 29H. When 
clear, the 772 only responds to 2DH. (2DH is the 
Supervisory Access mode; 29H is Non-privileged 
mode. ) 


AIO RESPONSE TIME - These bits respond to the four 
values that indicate the maximum AIO response 
time. This is the time from setting AIO to the 
time the 772 clears it. The shorter the response 
time, the greater the 772 overhead. 


Value Time 
00 100 us (Default) 
01 75 us 
02 62 us 
03 50 us 


Table 4-3. AIO Response Times 


4.2.2 IOPB Byte 9 (Controller Parameters B) 


_ THROTTLE DEAD TIME 


RESERVED | 


| 

ee ne ee ee re | 
RELEASE ON REQUEST... i (‘(‘(O;ONOOOONOCOC;C*é#*dLCC‘é*zC 
a) 


RESERVED 


Bit MM ic D tot; 


7-6 TDT 
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THROTILE DEAD TIME - When set, TDI selects one of 
four minimum time periods that determine the time 
the 772 remains off the bus between throttle 
bursts (see Section 8.5). 


RESERVED. 
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4.2.2 IJOPB Byte 9 (Controller Parameters B) (continued) 


Bit M nic I oti 


4 ROR 


3-0 


RELEASE ON REQUEST - When set, the 772 releases 
the bus at the request of other bus masters; 
otherwise it continues with the next throttle 
burst. The 772 monitors the bus request lines and 
releases the bus only if another bus request is 
pending. It completes its specified throttle 
burst before releasing the bus due to a pending 
request. If clear, the 772 releases the bus after 
every throttle burst and rearbitrates if more data 
transfers are pending. 


RESERVED. 


4.263 IOPB Byte A (Controller Parameters C) 


OVERLAP REWIND 


a | 
WRITE WAIT FOR DMA oe es Gl | | 
INTERRUPT AT END OF CHAIN a in 


RESERVED 


[71615 7;,4/1/3 /2/11/0]| 
| 6 


Bit MM ico I _ 


7 OVR 
6 WWD 
5 TEC 
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OVERLAP REWIND - When set, the 772 skips over an 
IOPB in a chain that is currently rewinding and 
executes commands for any drive not rewinding. 
The 772 remembers it skipped an IOPB and updates 
its status after the tape rewinds. When clear, 
the 772 waits for the drive currently rewinding to 
complete before executing further commands. 


WRITE WAIT FOR DMA - When set, the 772 will not 
start tape write transfers until the DMAC receives 
data. This ensures that Data Late errors do not 
occur when uSing drives with cache memories that 
respond to tape writes immediately. 


INTERRUP? AT END OF CHAIN — When set, the 772 
returns all IOPB chains with one RIO and one 
interrupt; it does not relink or unlink IOPBs. 
The RIO address of a completed chain is the 
address of the first IOPB in the chain. ‘The 772 
also uses the interrupt level and vector of the 
first IOPB in the chain. 
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4.2.3 IOPB Byte A (Controller Parameters C) (continued) 


Bit M iol tj 


5 IEC INTERRUPI. AT END OF CHAIN (continued) - When 
Clear, the 772 does not chain RIOs or IOPBs; it 
returns all chains unlinked. (Do not set or clear 
IEC while the 772 is processing an IOPB chain.) 


4-0 RESERVED. 


4.2.4 IOPB Byte B (Controller Parameters D) 


Bits 0 through 7 are the Throttle (THRO) bits. The throttle is the 
maximum number of transfers allowed each time the 772 becomes bus 
master. The throttle value determines the maximum DMA burst length 
for both data and IOPB DMA transfers. Each bit position represents 
a binary weight, allowing a throttle from 1 to 256. Table 4-4 
lists the throttle values. 


Value Weight 


0 256 
1 1 
2 2 
3 3 
255 255 


Table 4-4. Throttle Values 


4.2.5 IOPB Byte C (EPROM Release Level) 


IOPB Byte C contains the release level of the EPROM plugged into 
the board. 
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4.2.6 IOPB Byte E (Controller Type) 


IOPB Byte E is the Controller Type byte. Xylogics assigns each VME 
controller a unique controller type code. 


Controller § Code (H) 


712 12 
751 51... 
772 72. 


Table 4-5. Controller Type Codes 


4.2.7 IOPB Bytes 10 and 1] (EPROM Part Number) 
The 772 returns a portion of the EPROM part number. The four 
nibbles in these two bytes refer to the part number's last four 


digits. For example, if the EPROM part number is 180-002-138, Byte 
10 contains a 21(H) and Byte ll contains a 38(H). 


4.2.8 IOPB Byte 12 (EPROM Revision Level) 


IOPB Byte 12 contains the revision level of the EPROM plugged into 
the board. 
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4.3 


WRITE DRIVE PARAMETERS IOPB 


DRIVE PARAMETERS 
a ee aoe sf 2 ft tft co 


. 
1 See 
i rr ree 


DSB 
[.caP] | [row] | [so] | [ass] | 9 _| 
tL siservensitvtoszsope} 
fa 
a a 
Fa capes ac a a cel 
aes eee 
LTP CHECKSUMHTIGH] 
PC CHECKSUMCOW] 
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4.3.1 IOPB Byte 8 (Drive Parameters A) 


IGNORE READ ERROR se | |. | 
IGNORE WRITE ERROR a 


READ RETRY 
WRITE RETRY 


GAP RETRY ON WRITE 
TAPE DRIVE DENSITY SELECT 


SWAP WORD 
SWAP BYTE 


[7167/5 714/3 12/1/90] 


Bit ic I tot 


7 
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IRER 


IWER 


IGNORE READ ERROR - When set, the 772 ignores File 
Mark Detected On Read, Hard Tape, Corrected Tape, 
Record Length Long, Record Length Short, and Tape 
Parity errors; it does not set the various tape 
error bits or return a completion status. ‘he 
controller reports the type and number of ignored 
errors in Bytes A and B. 


IGNORE WRITE ERROR - When set, the 772 ignores 
Hard Tape, File Mark Write Fault, and Tape Parity 
errors; it does not set the various tape error 
bits or return a completion §§ status. The 
controller reports the type and number of ignored 
errors in Bytes A and B. 


READ RETRY - When set, and a hard error occurs, 
the 772 retries the Read command four times before 
reporting an error. 


WRITE RETRY - When set, and a hard error occurs, 
the 772 retries the Write command up to two times 
over the same area of tape; it reports a hard 
error if the error persists. 


GAP RETRY ON WRITE - When set, the 772 tries to 
write an extended gap over the section of tape 
where the error occurred during a Write operation; 
the controller repositions to the beginning of the 
record, writes a 3-inch gap (ERASE), and retries 
the write. The 772 repeats this procedure up to 
four times before reporting a hard error. 
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4.3.1 IOPB Byte 8 (Drive Parameters A) (continued) 


Bit M io I oti 


2 DSB 
1 SWWD 
0 SWBY 


DENSITY SELECT BIT -— When set, the 772 selects the 
tape drive density over pin Pl-36 with Codes 2 and 
3 of the density select field in Byte 9. Setting 
DSB also enables writing long interrecord gaps via 
pin Pl-44. When clear, the 772 selects density 
using Codes 4 through 7 of the density select 
field (this is the density defauit; you can select 
other codes with the Write Drive Parameters 
Subfunction Codes); this also selects Long Gap 
over pin P1-36. See Section 10.2. 


DSB Set DSB Clear 
Use Density Codes 0-3 Use Density Codes 4-1 
P1-36 Selects Density P1-36 Selects Long Gap 


P1-44 Selects Long Gap P1-44 Not Used 
Table 4-6. Density Selected via Command Lines 


SWAP WORD - When set, the 772 swaps’ the 
Significance of the two words in a longword (data 
transfers only). 


SWAP BYTE - When set, the 772 swaps’ the 
Significance of the two bytes in a word (data 
transfers only). 


4.3.2 JIOPB Byte 9 (Drive Parameters B) 


SELECT INTERRECORD GAP es | | 
INHIBIT PARITY ON WRITE ees ae 


SPEED SELECT 


-AUTO-STREAMING SELECT 


RESERVED 
DENSITY SELECT 
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[7161/5 1/4/13 127110] 


40 


XYLOGICS 772 Tape Controller User's Manual 


4.3.2 IOPB Byte 9 (Drive Parameters B) (continued) 


Bit MM io I tot; 


7 LGAP 
6 TPOW 
5 SPD 
4 ASS 
3 


2-0 DENSITY 
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SELECT INTERRECORD GAP - When set, the tape drive 
writes an extended interrecord gap. LGAP is used 
in conjunction with DSB (DSB determines which pin 
on the Pl connector selects long gap). ‘The actual 
gap length is drive manufacturer- and density- 
dependent. When clear, the drive uses the default 
interrecord gap size for the selected density. 


INHIBIT PARITY ON WRITE - When set, the 772 
ignores Read Parity errors during Write 
operations. Many tape drives employing cache 
buffers do not provide valid read after write 
strobes, causing the 772 to detect parity errors. 
When clear, the 772 checks read parity on writes. 


SPEED SELECT - When set, the tape drive remains in 
High Speed (Streaming) mode for all transfers. 
When clear, the tape drive runs in Low Speed 
(Start/Stop) mode. The tape drive you are using 
determines the actual speed. 


AUTO-STREAMING SELECT - When set, the 772 measures 
the time between commands (reinstruct' time) 
against preset values and automatically switches 
the tape drive into high speed or low Speed, 
depending on the comparison (see Section 8.9). | 


RESERVED. 


DENSITY SELECT - This field drives the density 


select line (P1-36) offered by certain 
manufacturers, or selects density via the tape 
command lines, depending on DSB'’s value. By 
writing a code in this byte, the 772 always uses 
that particular density wunleSs a separate Set 
Drive Parameters command changes the density 
State. Table 4-7 lists the density codes. 


Code Action 


Use Density Default 
Use Density Default 
Set Low Density Mode 
Set High Density Mode 
Set 800 BPI — Byte A 
Set 1600 BPI - Byte B 
Set 3200 BPI - Byte C 
Set 6250 BPI - Byte D 


SOA Om WHE © 


Table 4-7. Density Codes 
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4.3.3 


4.3.4 


IOPB Byte 10 (Data Busy Timer) 


This byte controls the timeout associated with the tape interface 
Signal Data Busy (DBSY). ‘This timeout is programmable because many 
of the caching tape drives have longer DBSY times during error 
correction. The default value (0) is a .25 second timeout and the 
maximum timeout is 64 seconds. Other timeout values are in .25 
second increments (see Table 4-8). Xylogics recommends values 
greater than 7FH for cache drives. 


Byte Value (Hex) Timeout (Seconds) 


0 029 
1 90 
2 0/5 
3 1.00 
FE 63.75 
FF 64.00 


Table 4-8. Data Busy Timeout 


IOPB Bytes A Through D (Density Select) 


[7161/5747 3 127/110] 


IGA eee! OUT 
TR io ee ee ey, 
Fe ee Cd 

| | | 
| | 
! 


The 772 uses these bytes to select the density of a particular tape 
drive via the standard tape interface command lines. ‘These bytes 
are only valid if DSB is clear. Each byte duplicates the tape 
drive command lines: A = 800 BPI; B = 1600 BPI; C = 3200 BPI; and 
D = 6250 BPI. 


Load the specific code for each density in the appropriate byte and 
execute the command. (Tape manufacturers use different codes to 
select density; since the code bits are not always in the same 
order from one manufacturer to another, the hex codes may not match 
ours, but the bits are always the same. See Table 4-9, or consult 
your tape drive manual for proper codes.) Each time a set density 
code or a Set Drive Parameters command is issued, the 772 uses the 
information in these bytes to select the default density. 
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4.3.4 | JOPB Bytes A Through D (Density Select) (continued) 


Command: SOO/NRZ 1600/PE 3200/PE 6250/GCR WRItVAR GAP 
Anritsu 2500 — 1C 1D —_ -_ 
Cipher F880 — — _— — — 
F890 pan 1C 1D —_— —_— 
M990 —_ 1C 1D 03 — 
CDC 92181 —_ ~— — — — 
92185 —_ 1C — 1D 82 
Fujitsu 2242 —_— 1C —_ 1D — 
Kennedy 9400 — — — —_ = 
9600 OE 1C —— ~— ~— 
Pertec FS1000 — * 1D — _— 
FS2000 13 1C 1D 03 oe 
STC 2920 — 1C — 1D — 
Telex Shamrock FC 7C* —_ 7D = 


Thorn 9800** — -— —_— — — 
9900 OA 1C 1D one OE 


Key: 


— The Tape drive will not support or select this density. Write 00 
in the associated byte. 


* Defaults to 1600/PE at BOT. 


** Selects density via interface pin Pl-36. 
Table 4-9. Density Selection Codes 


4.3.5 IOPB Byte E (Variable IRG) 


This byte enables the 772 to write variable length interrecord 
gaps; it writes an interrecord gap until the next record arrives. 
Use the values provided in Table 4-9 under WRI+VAR GAP. 
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4.4 COMMAND PASS THROUGH TO DRIVE IOPB 


This command allows the 772 to support any manufacturer's method of 
selecting a feature. The 772 allows you to directly interface the 
tape drive command lines. 


COMMAND PASS THROUGH TO DRIVE 


Easel Ee ee ee 


COMMAND 


E od NEXT IOPB ADDRESS MODIFIER | 


NEXT !OPB ADDRESS HIGH 
NEXT |lOPB ADDRESS 


NEXT IOPB ADDRESS 
NEXT |1OPB ADDRESS LOW 


; 1\OPB CHECKSUM HIGH | 
1OPB CHECKSUM LOW 
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4.4.1 


4.4.2 


IOPB Byte 8 (Byte Count) 


(716/;/51/4]3]2]1 40 4 
RESERVED dT 
BYTE COUNT | ee ee eee ee, 


7-2 RESERVED. 


1-0 BYTE COUNT - These bits determine the number of tape command 
bytes to send to the drive; 0=l1 byte, 1=2 bytes, etc. 


IOPB Bytes A Through D (Tape Command) 


These bytes allow software to directly manipulate the tape drive 
command lines, allowing the 772 to support all manufacturer's 
Special command sets. You must not use Command Pass Through To 
Drive with commands that require other parameters set, such as 
reads and writes. Typically, only the Tape Command byte is used. 
Megatape MT500 drives require a command plus a track number when 
selecting a track; in this case Bytes 1 and 2 are used (i.e., 
Command 1=Select Track; Command 2=Track Number). See Section 8.10. 


TAPE COMMAND BYTES 1-4 


l|71615/4]312]1]0 4 
LGAP _| | | | 
THRE: | | | 
HSP eee | 

| 
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5.0 


5.0.1 


5.0.2 


SECTION 5: COMMANDS 


GENERAL 


Each tape command begins a new page. An IOPB diagram follows each 
command description. The diagrams are highlighted to indicate 
which fields the 772 absolutely requires for execution, which 
fields are optional for the command, and which fields return after 
command execution. 


Each 772 IOPB is 26-bytes long. Reserving all 26 bytes in memory 
(for each IOPB) maintains IOPB integrity. Generally, all commands 
use Bytes 0 through 19H. 


Setting Up The Command 


Each IOPB diagram indicates the bytes or fields that must be set 
for each operation. Certain parameters are essential; others are 
optional. All commands reguire the Command, Unit, Interrupt Level, 
and Interrupt Vector fields to contain valid information. 


Completing The Command 

After the 772 completes the command, it updates IOPB Bytes 0 
through 3 with ERRS, DONE, a Completion Code, and tape drive status 
information. The 772 only updates the entire IOPB if Auto-update 
(AUD) is enabled, an error occurs, or a command returns information 
via the IOPB. If AUD is set, and no errors occur, the 772 sets 
DONE, posts a Completion Code of zero in Byte 1, and the tape drive 
status in Bytes 2 and 3; for any command that DMAs data to/from 
Memory, the 772 updates the data address to point to the last 
address plus one of the transfer. See Table 5-l. 


Status Action 


AUD Clear/No Error 772 updates Bytes 0-3 with ERRS, DONE, 
Completion Code, and tape status 


AUD Set/No Error Occurs 772 updates the entire IOPB 
AUD Clear/Error Occurs 772 updates the entire IOPB 
AUD | Clear/Command Returns 772 updates the entire IOPB 
Information Via the IOPB , 


Table 5-1. Command Completion 
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Sel NO OPERATION 


The NOP command is a diagnostic tool; the 772 reads an IOPB from 
memory into its IRAM and DMAs it back to memory marked DONE. You 
can run this command by setting the NOP code in the Command byte, 


NOP 


oo HPERRS II [Lone ||| (cHen| | [sem] V/A Command CODE = 0 V7) 


aneseuae BoY a Vy, 
PRT ERRARARERERERPSSRERSCRRECRESEEEESE Ease Asess HATA 
ot (TTA TLTATINIMI[ComPLerion cope 


| 
a LAA EERE LLL 
of Os «CT) 
ig 


ES A LY A OS 


ET EE AE EN EE EE A a 


08 REQUESTED COUNT HIGH 
09 REQUESTED COUNT LOW 


OA LAST RECOVERED/IGNORED ERRORS 
OB COUNT OF RECOVERED/IGNORED ERRORS 


oc ACTUAL COUNT HIGH 
oD ACTUAL COUNT LOW 


ee ae DATA OR LINK ADDRESS MODIFIER 


. 738 
seoe8 g3t3t 
tH 
3: 

3 
333 3s 


OF [eb : 


EPP COPEL PELL LOFT IOI OIC ODD ILI OP OL LAI CI CILLA AL AL ALO ALCL CL CLL CD CPLA ALIN LOL LOD PEL PLILPEDESZPLPLPL LP LPL PLIES EPL PL LEEPER E DLE PERE RLS FESS TRE EDS Pe) 

eee eee ete t et ale t ce 5 > padbanuctienMetaintnatentestaathatantinetiontinnatatinatinartiadindiraiettetndinsatadmatetnatutettntintinttnating +? 2 sic lose cetera lesete tase tetetatesesacerntete 

PPPS Pe P ee PtP bs ot Pt Pe eS Pe Pee Tee Pee See Pe Pee Oe Peet ee Pe Pe Pe be Pe) ee eenrennmmmmaas Sit bth Streit ee ose Siti tt htt Steeler er et it eee Ft Sees He et ee hte 

woese 
ogee 

age 

io face 


POOOOCOONOOOOOI0000006000-0000(h0) 


ezese 
$83 
32333 
soiss 
338 
$3 
ote se 
3 
oosss 
258 
sess 
e233 
sgegs 
sgege 
33388 


agete 

ofoke 

egete 
‘efe 


sgsseseesessess itt eteree settee testes tte eey 
Sleseseseteleseses cesses sesesesetececesssesesecs 
se ressessssesscecsess ss seesseesseselesssessssescesecessoes 
. > eta ta ate tats tatetetete erect anata erates esate tat et stots ia 
_ . 
Wy r eeteteseesovers eusecteseeey® 
e ul ed Sigsessessetsss SSesteeeees teed 
esete, oe ete e see tate? 
Ssoesssssses ces ssesssesessees 
tote tet eter ee acess set esete: 
PoP ht 4 tos ot P e3 osesese 
2 petreteiieetrisrasreritertsrss testes ts) 
Sssgsse sisssgs Sgegsesesss 
y PeeSSeRS Sr eeeeeeeee esters esesti sess 
Pitssesestrasstessterestteeessttrersse 
Z) : seceissss s33 
s 5 3 : 


Optionally LUUIAIAIAHAH Returned 
Required Value 
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5.2 


WRITE DATA 


After reading and decoding the IOPB, the 772 reads the data from 
host memory and writes the data contiguously to the tape. 


Write Data has two IOPB formats. In Normal mode, the IOPB 
specifies one contiguous block of data to write to the tape. ‘The 
transferred record can be l- to 65,536-bytes long. 


In Gather Write mode, the IOPB specifies up to 32 different host 
memory data blocks, of varying sizes, to write to the tape. The 
block can contain any even number of bytes and the total must agree 
with the byte count. (A zero in the count field equals the maximm 
record length [65,536 bytes]. FFFF[H]=65,535.) See Section 8.4 
for more detail on Scatter/Gather operations. 


WRITE DATA 


3 3 
ofesel [SGM } 
ie HH 

3238 ets esse ots 


a. LF A a A 


[son] 7 YEE 


EP EE LTP SE LP AD AP AED EEE A 


/A INTERRUPT a 


FT OT a Comey / 


Zs 8S LLL 


LT a OE A a a 


——— ADDRESS HIGH [7 Wai: 
oes 


[lOPB CHECKSUM LOW | 


UY Required ce] Optionally MM Returned 
ZA For Execution £22 222) Required Value 
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5.5 


READ DATA 


After reading and decoding the IOPB, the 772 reads the specified 
number of bytes from the tape, and writes the data to the specified 
host memory address. 


Read Data has two IOPB formats. In Normal mode, the IOPB specifies 
one contiguous block of host memory that the 7/2 uses to place the 
data from the tape. The transferred record can be l- to 
65,536—-bytes long. | 


In Scatter Read mode, the IOPB specifies up to 32 different mses 
of host memory, o£ various size, where the tape data is to he 
placed. The block can contain any even number of bytes and the 
total must agree with the byte count. (A zero in the count field 
equals the maximum record length [65,536 bytes]. FFFF[H]=65,535.) 
See Section 8.4 for more detailed information on Scatter/Gather. 


READ DATA 


LO A A a ae 


Ee 
YUERESELAYU 


eee er 
MM 
do EL dedled 


LP a 


Z 


|OPB CHECKSUM HIGH}: 
lOPB CHECKSUM LOW 


WEEE. Forsartion cures” (UUM oe 
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5.4 POSITION 


The Position commands move tape forward and reverse over 
records or files, without transferring data. The 772 uses the 
count field to set up the number of records to space over or 
the number of file marks to search for or skip. 


POSITION 


_— aI 


oe 
CLA COMMAND CODE = 3 V///7, 


CHEN] COMMAND RODE SS 
ESI CeaI co oe eine 


TH | 9 yyy 


DT AT ED ED EE A A A SO 
TE A A ED A A 


yy 


DATA OR LINK ADDRESS HIGH 


DATA OR LINK ADDRESS 
DATA OR LINK ADDRESS 
[DATA OR LINK ADDRESS LOW | 


statetetares 
ecere set ates 
PTLSPS ISTEP ELI TS SEL SST LE SST TPL TLS SP TIS Pee Steet er eS sete Pte T Tete tet eed 
STS SE SESS IS IETS S STS TSSELIS SSL SS SSL S PESTS TST SS TSS ESSE ST OLS SILT SSS CSTE TPS T ETS 
este ceases ese e ses ee sce se tase casesasacecectces see sececosocecccecesosesocoessea MET VF FPA Efe APU PY DE Co Co LIF OLE feocetcccscce cet cccsccese case ace ses ese sete cece ce se cela sa se tete sacs tstatecs cass? 
eo see ett e settee letecetesesesesesssetecetesacesetesetssosesesesotasasetesosesesscocora INE bm M FF Ff Pht Pe SAT NE ) bet be SR had Tf um bak Boetscecc cece c tees sce ct ese cesses scesscecetstetatecesecesseseesetososesesessess 


eo 
fe 
3000-0-000000-0000000000-000000000000 


rs 
ete 
set et at otese 


BA 
siete 
ogsse 


00-0-0-000-0-00.0-00-00000000-000000000000 
0200-000000000006000-0.0000000-00-000 
‘.. 
joceges 


rt 
gs$e 
90-0-:0000.0-0.000-00-0-000000000000000-000-0LK35 


WD, For Execution [::sssceseeneeel Required Value 
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5.4.1 Position Subfunction Codes 
Code Description 


20 


21 


40 


4) 


42 


SPACE RECORD FORWARD: spaces forward the number of records 
specified in the count field. Each count places the tape 
head in the interrecord gap that separates records from one 
another (see Figure 5-1). If AUD is set, the 772 reports 
the actual number of records spaced over. If the 772 
detects a tape mark, tape motion ceases and the controller 
reports a File Mark Detected On Read error. 


SPACE RECORD REVERSE: same as the Space Foward command, 
except records are spaced in the reverse direction. ‘he 
772 aborts this command if it encounters a BOT marker 
(Reverse Into BOT error). 


FILE MARK SEARCH FORWARD: searches forward the number of 
file marks specified in the count field. Each count places 
the tape heads in the interrecord gap just after the file 
mark in question. If AUD is set, the 772 reports the 
actual number of file marks found. If this command is 
issued, and there are no file marks on the tape, the 772 
searches until it detects EOT. 


FILE MARK SEARCH REVERSE: same as Search Reverse, except 
the 772 searches for file marks in the reverse direction. 
Each count places the tape heads in the interrecord gap 
just before the file mark in question. The 772 aborts this 
command if it encounters BOT. 


MULTIPLE FILE MARK SEARCH FORWARD: searches forward for a 
specified number of consecutive file marks. This is 
especially useful for positioning the tape heads at the 
logical end of tape (usually indicated by several 
consecutive file marks). This command follows the same 
completion rules as File Mark Search Forward. 


TAKE-UP NO DATA 25 FT. 


Figure 5-1. Typical Tape Format 
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5.5 DRIVE RESET 


The 772 commands the drive to reset, go on-line, go off-line, or 
rewind. 


DRIVE RESET 


[scm] YZ COMMAND CODE = 4 W/Z 


} oO YZ 


REQUESTED COUNT HIGH 


OOOO OD000O DL 


$3: ie 

$3: 
Th 33 
ose bf 
ee 


° 
° 
. 


rf 
‘ 
: 


=| NEXT LOPB ADDRESS HIGH fF: 


ZA For Execution £2:2:555555) Required Value 
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5.51 


Drive Reset Sub£function Codes 
Code Description 


00 


20 


21 


22 


DRIVE RESET: resets the tape drive by dropping the 
Formatter Enable signal. Use this command if a tape 
runaway condition occurs. Always consider the tape 
position unknown following a Drive Reset. 


LOAD ON-LINE: brings the drive on-line and to load point 
(BOT). This is useful in remote installations if a power 
loss occurs. Only certain drive manufacturers support this 
feature. 


REWIND: moves the tape at high speed in the reverse 
direction until the BOT marker is detected. ‘The tape drive 
should indicate it is at BOT or load point. ‘The Rewind 
command completes immediatly, although the tape is still 
rewinding. To verify the tape drive has completed 
rewinding, software must issue either a Read Drive 
Parameters or a Drive NOP command. The following 
conditions should be true: BOT set, REW clear, and DRRDY 
set. (Caution: even if REW is clear, the drive may not be 
ready [DRRDY clear]). 


OFF-LINE/UNLOAD: moves the tape at high speed in the 
reverse direction until the BOT marker is detected. ‘The 
tape continues moving at low speed until it loses tension 
and the drive goes off-line. The Off-line/Unload command 
completes immediately, although the tape has not completed 
the operation. To verify the tape drive has completed 
unloading, software must issue either a Read Drive 
Parameters or Drive NOP command and examine the status of 
the ONLIN bit in Byte 3. 
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5.6 WRITE PARAMETERS 


The Write Parameters command writes controller parameters or drive 
parameters, depending on the subfunction. (A Write Controller 
Parameters command must have a valid checksum value if you are 
setting ICS.) 


5.6.1 Write Parameters Subfunction Codes 


Code -—sc Description 


00 WRITE CONTROLLER PARAMETERS: initializes the 772 with 
its operational parameters. These parameters are 
permanently written into a battery backed-up RAM. Only 
reissuing the command or an IRAM failure causes the 
parameter values to change. Sections 4.2 through 4.3 
define how to change the parameters for individual 
applications. The 772 assumes no default parameters, 
however, Xylogics sets parameters during diagnostic 
verification at the factory. 


WRITE CONTROLLER PARAMETERS 


no HILERRS HII [OONENH LcHen | [som] (7/7 COMMAND Cove = 5 W777 


Demm TALLUTHAANAAAUUAALAUALANALNALAALAAEL FITAUNTAANTUUAUATAGAALGAAA THAT 
| [Her] | [cer] | [rcs] | [Rec] | Cemk] | [Peto] | feot) | [wer] 
ae ee (ee 1 ee 


Cohen dicre dante 


CONTROLLER TYPE 


EPROM PART NUMBER HIGH 
: EPROM PART NUMBER LOW . 
EPROM REVISION LEVEL 


14 ZS rath dinteh lide : 


NEXT 10PB ADDRESS 


|NEXT 1OPB ADDRESS LOW 


PPBO0-0.000-0-00000000000000000 


OPB CHECKSUM LOW 


Yi) pars 


=f Required Value 


\ 
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5.6.1 


Write Parameters Subfunction Codes (continued) 


Code 
20 


, Ot; 


WRITE DRIVE PARAMETERS: the 772 sets the various tape 
drive parameters; it assumes no default values, but once 
loaded, the parameters remain stored in the 772 IRAM. 
Only reissuing the command or an IRAM failure causes the 
parameter values to change. Like Controller Parameters, 
the 772 has Drive Parameters that were set by factory 
diagnostics. Up to eight different sets of drive 
parameters can be stored by Unit Number in the IRAM. 
After issuing this command, use the Set Drive Parameters 
command to quickly change parameters. 


WRITE DRIVE PARAMETERS 


ics | ee 7/7 
eee 
[Fr 


aasecasaana ssanueasees 
emepnepngnmmmeneaams A 


Li 
ZG VW 


AF A a A a a 


DENSITY 


a a a P| 
Selelatetasasetateterets 


LLL, Fs. cccree® COMIN i" 
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5e/ 


SJ el 


READ PARAMETERS 


The Read Parameters command reads controller parameters, drive 
parameters, or drive sense information, depending on_ the 
subfunction. 


Read Parameters Subfunction Codes 
Code Description 


00 READ CONTROLLER PARAMETERS: returns the controller 
parameters written by the last Write Controller Parameters 
command; it also tests the IRAM checksum. Bytes E through 
13. contain specific controller type and revision 
information that is stored and read from the EPROM. 


READ CONTROLLER PARAMETERS 


ae 


“sss A COMMAND CODE = 6 WY) 


LP ED PD A a a 


7 
———— 


P SS RR RRR ARRR RRR REE | ; | Ret - 
WLLL, or execution [a ne TN se 
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Be led Read Parameters Subfunction Codes (continued) 


20 READ DRIVE PARAMETERS: returns the drive parameters 
written by the last Write Drive Parameters command for the 
unit selected, and the IRAM checksum. 


READ DRIVE PARAMETERS 


EC auhennathenusth nmitbarhhernutrnnthannthennomrthcmcdheamdbeanuth 


YY; 


Yl 
Lz muy, 


ayy 


(ace CHECKSUM HIGH 
| flops CHECksum Low] 


YU) Required aan SR ERRRRRO DR: 
ZA ForExecution [22253585 8 


=] Optionally TU Returned 
Hiei} Required Value 


Rev. B. August 15, 1987 57 


XYLOGICS 772 Tape Controller User's Manual 


5/1 


Read Parameters Subfunction Codes (continued) 
Code $$ Description 


40 


4] 


READ SENSE BYTES: returns drive-specific status and 
diagnostic information to a host memory buffer specified in 
the IOPB. This command is similar to the Read command 
format in that it requires a byte count and buffer address. 
Consult your drive manufacturer's manual for the number of 
bytes returned and their definitions. 


READ EXTENDED SENSE BYTES: this command is almost 
identical to the Read Sense Bytes commands, except the tape 
drive provides more information. This command is mainly 
used for diagnostic purposes. 


READ SENSE / READ EXTENDED SENSE 


IP77#00-00000000G 
age 35 
#1 CHEN | 

gets 

#1 CHEN | 

HE: 


ee Ul 
Witla nee LL 
WHT sem i YyyysrswH 


CMMMM!Z?7™!//E YY ddd 
| 


COUNT OF RECOVERED/IGNORED ERRORS 


OPB CHECKSUM LOW 
Yyi iff nequired Bie eee] Optionally Returned 
ZA For€xecution [2 =] required ee 


N 
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58 


5.8.1 


EXTENDED WRITE 


This command controls three separate Write functions: Write File 
Mark, Erase, and Write Continuous. These functions require 
different IOPB formats. Section 5.8.1 explains these functions and 
follows with IOPB diagrams. 


Extended Write Subfunction Codes 

20 WRITE FILE MARK: the 772 issues a Write File Mark command 
to the tape drive. File marks are special records that 
logically group data records on tape. Host software should 
write at least one file mark (preferably two) at the 


logical end of tape. (Write File Mark uses the count field 
to specify the number of file marks to write.) 


WRITE FILE MARK 


DONE} |] [CHEN | 


LOE 
a ee 7: wm//// 

an WA GY, 
WWII: IEEE 
Wiittiiiltan. WWMMMU“aedeen: 
UMMM 


a a | 


ee 


DATA OR LINK ADDRESS HIGH | 
DATA OR LINK ADDRESS 
[DATA OR LINK ADDRESS 


ATA OR LINK ADDRESS LOW 


y, | R ired Me 
LLL, For Execution Eo — (vere 
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5.8.1 Extended Write Subfunction Codes (continued) 
Code Description 


21 ERASE: the drive erases 3-inches of tape per command. The 
only IOPB parameters ERASE requires are the Command and 
Subfuntion Codes. Use this command to erase over bad tape 
when write retries are not enabled. 


ERASE 


O/ZAINTERRUPT LEVEL) 


(de 


WMO 
Pr Reauesre coun io) 


- . 4 


REQUESTED COUNT LOW 
LAST RECOVERED/IGNORED ERRORS | 
COUNT OF RECOVERED/IGNORED ERRORS 


| ACTUAL COUNT HIGH | 


ACTUAL COUNT LOW 


DATA OR LINK ADDRESS MODIFIER 


DATA OR LINK ADDRESS HIGH | 
DATA OR LINK ADDRESS 


DATA OR LINK ADDRESS 


DATA OR LINK ADDRESS LOW 


eeeete® 
etese 
soegses 
soegere 
veotets 
sregete 
theses 
beets 
ocatete 
otetess 


=] Optionally LUUUUAIANAIAI Returned 
24 Required Value 


Yi] foe HEHE: 
A, For Execution EE anit 
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5.8.1 Extended Write Subfunction Codes (continued) 


Code Description 


40 WRITE CONTINUOUS: allows the 772 to write records of 
unlimited size. IOPBs must be chained or queued for this 
feature to work. All data addresses must be on a word 
boundary, and the byte count must be even. 


When the 772 


completes the byte count of the first IOPB, it decodes the 
next IOPB, and begins the data transfer without letting the 
tape drive write an interrecord gap (the 772 never. sends 
the Last Word signal to the tape drive). The FIFO empties 
if software fails to supply the next IOPB address in time 
for the 772 to decode it and DMA data to the FIFO. At this 
point, the 772 writes an interrecord gap which effectively 
treats the last Continuous command as a standard Write (and 
a Continue Reload error occurs); in normal operation, 
terminate Write Continuous with a standard Write command or 
a Continue Reload error will occur. Xylogics recommends 
implementing a circular buffer scheme to compensate for the 
large amount of memory this feature requires. 


WRITE CONTINUOUS 


: 


YN 
WLLL 
CW 


MHL 
YY. 


NEXT 1OPB ADDRESS 


EL Fee ttn Fe) ey I) er" 
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5.9 EXTENDED READ 
5.9.1 Extended Read Subfunction Code 
: _ 


40 


READ CONTINUOUS: allows the 772 to read records of 
unlimited size. IOPBs must be chained or queued for this 
feature to work. All data addresses must be on a word 
boundary, and the byte count must be even. When the 772 
completes the byte count of the first IOPB in a chain, it 
decodes the next IOPB, and begins the transfer where the 
first transfer left off. If software fails to supply the 
next IOPB in time for the 772 to decode it, the FIFO 
overflows with data from the tape record, and a Continue 
Reload error occurs. ‘Terminate Read Continuous with a 
standard Read command or a Continue Reload error will 
occur. Using a circular buffer scheme helps compensate 
for the large memory this feature requires. 


READ CONTINUOUS 
a Ce Ee Ee I 


WY 


4 


y R ired nae . 
WLLL, For bxecution |, Cas 


Rev. B. August 15, 1987 62 


XYLOGICS 772 Tape Controller User's Manual 


5.10 DIAGNOSTICS 


The 772 provides both on-board self test diagnostics as well as 
drive-specific tests and functions. 


5.10.1 Diagnostic Subfunction Codes 
00 SELF TEST: the 772 executes the on-board Self Test code; 


it reports errors from this test in the Fatal Error 
Register (see Section 6). You can only use Self Test with 
a single priority IOPB (i.e., no chaining, and no IOPBs in 
the 772 queue). 


SELF TEST 
~ (recznelllivso Ilfllfeor| ecw lll oes’ ltresy Ifoeeovl | (onc 
oe a 
INTERRUPT LEVEL 
‘ 


sant REQUESTED COUNT LOW 


OA LAST RECOVERED/IGNORED ERRORS | 


ae COUNT OF RECOVERED/IGNORED ERRORS | 7 
es ACTUAL COUNT HIGH 


a ACTUAL COUNT LOW 
i a ae oe [DATA OR LINK ADDRESS MODIFIER | 


7 


“or NEXT |OPB ADDRESS MODIFIER | 


_ DATA OR LINK ADDRESS HIGH 
i: DATA OR LINK ADDRESS 
49 DATA OR LINK ADDRESS | 


. — 


13 DATA OR LINK ADDRESS LOW 
‘a NEXT 1OPB ADDRESS HIGH 
| NEXT 1OPB ADDRESS 


‘NEXT IOPB ADDRESS 
| NEXT IOPB ADDRESS LOW 


r TIOPB CHECKSUM HIGHT. : 


ets 
soeyasesece 
CSSEIS TEE TY 
Seselesess 


$e. 
sos 
: 
33 
. soe3. 4 
s2tgsss 
coset eases 33 
Secesesotess et 
PRESTR ASRS SST ASAST SSRI SUAS ESAS ISHS EHE ETO IOERUS RROD 290-00000000000000-00600000000-0-0000 


4 i ae TEE | j : . 
WLLL ‘For execution L____ | reauirec LMI verve” 
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5.10.1 Diagnostic Subfunction Codes (continued) 
Code Description 


40 LOOPBACK TEST: issued to the tape drive formatter as a 
Write command, but the tape is not written. The data 
received is routed through the write logic of the drive 
formatter, back through the read logic of the tape drive 
interface, and then back to the read logic of the 772. The 
772 checks the parity of the read data, but does not store 
it. Use this tape drive diagnostic to check the 
formatter's read and write functions. Only certain tape 
Grive manufacturer's support this command. 


LOOPBACK TEST 


2 
TP OF SO Sa 


sig ACOMMAND CODE = SW 


CMMs YM) 
ee eee oe Fam 
nine: V/funrennurr teva V7 
LLL. eee LLL 
MMe MMM 


Y ppnnnnanppppnaacnsey Ret d 
GH; ee aib & ee te TAUUTATAAAAH ae 
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5.10.1 Diagnostic Subfunction Codes (continued) 
Code Description 


4l SECURITY ERASE: the drive erases the entire length of tape 
to EOT; then software must issue a Rewind command. This is 
commonly used to erase a tape that has old data or to 
retension the tape on the tape reel. 


SECURITY ERASE 


2 


WI; 
| (LINKLISTLENGTH] — UVFINTERRUPT LEVEL 


[REQUESTED COUNT HIGH 
REQUESTED COUNT LOW | 


~ [LAST RECOVERED/IGNORED ERRORS | 
COUNT OF RECOVERED/IGNORED ERRORS 


ACTUAL COUNT HIGH 


| ACTUAL COUNT LOW 


a: a | DATA OR LINK ADDRESS MODIFIER 


ehetet 
etese: 
atses: 


Yh} Required Tees] Optionally LUNUIAUUHTAIAT Returned 
ZA For Execution pe:ceeee 38 Required Value 
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Sell ABORT 


The 772 aborts IOPBs by unit number and interrupt level. The IOPB 
must specify which unit number and interrupt level to abort. ‘The 
772 returns all IOPBs chained or queued with an Abort By Command 
error; it does not abort the IOPB currently in process. Use this 
command when error recovery procedures fail to clear a hard error 
condition. 


ABORT 
< Ss 
> (EEE =| een YZ 
be | VA ZA\NTERRUPT LEVEL GW, 
: 


09 REQUESTED COUNT LOW 


OA LAST RECOVERED/IGNORED ERRORS | 


OB COUNT OF RECOVERED/IGNORED ERRORS 


oc ACTUAL COUNT HIGH 


B33 330800 ee NNN NN eee RESET SRST ES ES ESET ES PEPER ET ET SLES PEL ES ST ETE SET ETE eee rere eter rrr i 
oface . 

afate 
geso 


00-000-000050-00000000000000000000 


; R e q ul re d SSSSSSSsssssT: BIE TANAUIANAAIAIH R e t u rn ed 
A For Execution Peccssseessueel Required Value. 


osege 
sssgss 
esses 


323 
Se sessessseses: 
SSOP eS S tT 
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5.12 SET DRIVE PARAMETERS 


This command allows you to change a Single drive parameter, via 
Subfunction Codes, without having to set up all parameters as in 
the Write Parameters command. The Subfunction Codes use the 
parameter information already present in the IRAM that were 
initially written with the Write Drive Parameters Command. 


SET DRIVE PARAMETERS 


essegaaeaan ‘* ese ET EE EE A A EP A A A A a 


DOOD 
SSRCARESSRRARESEESSSATASSARLaR 


os LCC/ne TI Hiso UI iifeor | PRew | fipoesy [| Ceesy Iii RRov | ONLIN. 


"\§ MMMMM@ Oo YY 


of MVE NLL. 
06 TRINKLISTLENGTH] CJ AINTERRUPT LEVEL 4 
"a WIMMMHqH@EM’"/’NM IY 


DOELSRSES EES SEL EEE SES ee Deed SESE RE EL sD eLEEDEES SESE SEEE SS EEEE DE Soe EE SESE S SEES ESE ES ES 2s pntocasetadtedintedantniededaeatintaatetindatiditedadanietatutetetnctndbetesttindadiatenntetelals 2s 343s seis 
the 
peS3isees 


ren) 
egete 
asece 
esate 

ese 
soese 
atege 
egecs 

soe 
2° 


efesede 
egese 
ssesese 


ese 
esese: 
os esess esese: 


SIRE Optionally nM eee 
se 222) Required Value 


Yt ee el 


COREKXETEIK CONNIE CORRE COKER, CREE 
RS FR SS ee 
N CS BS ES ees cooeeeee 


Rev. B. August 15, 1987 67 


XYLOGICS 772 Tape Controller User's Manual 


5.12.1 Set Drive Parameters Subfunction Codes 
Code Description 


40 


42 


43 


DRIVE NOP: supplies Tape Drive Status Bytes 2 and 3 with 
information that is not normally returned in a controller 
NOP command. This command is useful for determining drive 
Status during Rewind or Off-line/Unload commands. 


SET LOW DENSITY: selects low density for drives that use 
the tape interface signal P1-36 for selecting density. ‘The 
DSB bit in Byte 8 of the Write Drive Parameters IOPB must 
be set for this feature to work. ‘The definition of low 
density is manufacturer-—dependent. 


SET HIGH DENSITY: selects high density for drives that use 
the tape interface signal P1-36 to select density. The DSB 
bit in Byte 8 of the Write Drive Parameters IOPB must be 
set for this feature to work. The definition of high 
density is manufacturer-—dependent. 


The following Subfunction Codes select combinations of tape speed 
and interrecord gap length. ‘Typical tape speeds are combinations 
of 12.5 IPS, 25 IPS, 50 IPS, 75 IPS, 100 IPS, 125 IPS and 200 IPS; 
the manufacturer normally supports a selection of two tape speeds. 
Normal interrecord gap length (IRG) is a function of the density 
selected. For example, 1600 BPI has a normal IRG of .6 inches; 
6250 BPI is .3 inches. Long IRG is typically double the normal 
size; consult your drive manual. 


Code Description 


48 
49 
4A 
4B 


SET LOW SPEED AND NORMAL GAP, 
SET HIGH SPEED AND NORMAL GAP. 
SET LOW SPEED AND LONG GAP, 
SET HIGH SPEED AND LONG GAP. 


The Set BPI commands use the values written into the IRAM from the 
last Write Drive Parameters command. 


44 
45 
46 
47 


SET 800 BPI. 

SET 1600 BPI. 
SET 3200 BPI. 
SET 6250 BPI. 
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weseseness 
seees 


Z 


LL 
WZ 


INTERRUPT LEVEL 


ateeeseee 
seurevee 
‘Seveeeee 
CO 
evenvncees 
euecesecse 
‘eee 


Returned 
Value 


Wd 
WU 


i] 


C 


Ze 


eseosouves O ooo 
COO 


stecveesees 


a ae aw 


UNIT 


(7-7-2 


LL, 


eceorevee on 
‘* @ecvcessee 
Seeeeecoes 


COO 
COON 
soeee 


EE EE FEE ATE EB ES ES I EO ET ee 


LM LLL. 


PRUs IL RL | oeocennecoBGl EEpacssaasacs 
SUBFUNCTION CODE = 40 | 
% 
ZY 
Wt. 
A /ANTERRUPT VECTOR Y///7 
is ne eee 
Z/ATAPE COMMAND BYTE 1/7 
TAPE COMMAND BYTE 4 


‘tees 
Cesersecen 7 

. eveeeess 
seesene: 


seeceonecs. 
. ates 
seesceeee 


ES ET IT FE SE EP EE ET SE ET A LP 


COMMAND CODE 


LF A a A 
Cf 


a ae ee 


Optionally 
ire 


Requ 


ee: 
soovceness 


| 


ecoevetaee 
on 


eeeeeoeess 
‘eerecee 
weveesecee 


Required 


Cc 
Oo 
~ 
pa | 
Q 
a) 
x 
tu! 
L.. 
Oo 
Li. 


LL 


LLL 


| 


I 
LL 


LLL 


| 


cote ta tates etetete 


| 


20 e 
Veecneree Mm espevceces 
ewe ve . 
weeseccceeMtntescesce 
seeereoers see 6 
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6.0 


6.1 


6.1.1 


SECTION 6: ERROR PROCESSING 


GENERAL, 


This section describes how the 772 handles error conditions and 
Suggests error recovery procedures for the device driver. 


ERROR REPORTING 


The 772 posts assorted controller and tape drive status information 
in each completed IOPB. After successfully completing a command, 
the 772 only updates Bytes 0 through 3 if Auto-update (AUD) is 
clear. Byte 0 indicates whether the controller completed the 
command and/or whether an error occurred. Byte 1 contains a 
Completion Code. Bytes 2 and 3 contain tape status information. 
If an error occurs, the 772 updates the entire IOPB, regardless of 
AUD's status. When the 772 reports an error in the Completion 
Code, do not assume that the reported error is the only failure 
that occurred. Bytes 2 and 3 contain additional error and status 
information that is useful in recovering from the error. Depending 
on the type of command, the 772 updates other parameters upon 
completion, 1.e., actual count, data address, etc. 


The 772 issues an interrupt (if enabled) after completing a 
command. Check the Fatal Error (FERR) bit in the CSR. If FERR is 
set, the controller probably did not DMA the command properly due 
to a hardware failure or address alignment error (read the Fatal 
Error Register to determine the cause of the error). If FERR is 
Clear, you can examine the completed command. Determine if the 772 
executed the IOPB (DONE), and if an error occurred (ERR). If ERR 
is set, read the Completion Code and two Tape Status bytes, and 
execute the appropriate recovery procedure. If ERR is clear, you 
still might want to examine these bytes to know the nom-error tape 
status (i.e., BOT, PEID, etc.). 


IOPB Byte 1 (Status Byte 1) 


Completion Codes follow a convention that indicates the action 
required by the software driver (some Completion Codes indicate the 
need for manual intervention). ‘The upper nibble of the Completion 
Code byte is the recovery code and the lower nibble is the actual 
error code (see Table 6-1). Table 6-2 lists the Completion Codes 
(all codes not listed in this table are reserved). 
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6.1.1 IOPB Byte 1 (Status Byte 1) (continued) 


Recovery Code Recovery Procedure 
0 No Action - Status Only 
1-2 Non-retryable Programming Error 
3 Successfully Recovered Soft Error 
4-5 Hard Error — Retry | 
6 Hard Error — Reset and Retry 
7 Hardware Error 
8 Miscellaneous Error 
9 Requires Manual Intervention 
A You're Lost 
B-F Reserved 
Table 6-1. Recovery Codes 
No Action / Status Only 00 Successful Completion 
Non-retryable Programming 10 Density Change; Not At BOT 
Errors ll Illegal Parameters Combination 
12 Cont. Gnd. Odd Addr. or Byte Count Error 
13 Count Zero 
14 Illegal Command 
1c Illegal Scatter/Gather Length 
1E Next IOPB Address Alignment Error 
21 Tilegal Black Hole Transfer Address 
Successfully Recovered 30 Corrected Data 
Soft Errors 
Hard Errors -— Retry 40 Hard Tape Error. 
41 End O£ Tape Detected 
42 File Mark Write Fault 
43 Operation Timeout 
44 DMAC Timeout 
45 Tape Parity Error 
46 FIFO Buffer Parity Error 
47 Record Length Long 
48 Record Length Short 
49 Data Late Detected 
4A Fatal DMAC Error 
4B VMEbus Error 
4C Continue Reload Error 


Table 6-2. Summary of Completion Codes 
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6.1.1 IOPB Byte 1 (Status Byte 1) (continued) 


Action 


Hard Errors - 
Reset and Retry 


Code (Hex) Description 


60 Drive Fault (Pertec FS Series Only) 
61 Drive Not Ready 


Hardware Error -— No Retry 71 Firmware Failure 


Miscellaneous Errors 81 IRAM Checksum Error 


Requires Manual 
Intervention 


You're Lost 


82 IOPB Aborted By Command 
83 IOPB Aborted by Error 


90 Tape Reel Write-protected 
91 Drive Off-line 


AO Reverse Into BOT 
Al File Mark Detected On Read 


Table 6-2. Summary of Completion Codes (continued) 


6.1.1.1 Completion Code Descriptions 


Code(H) Description 


00 


10 


11 


12 


13 


14 


SUCCESSFUL COMPLETION -- Not an error; indicates the 
command is complete and the IOPB may be removed from the 
queue. 


DENSITY CHANGE NOT AT BOT — Software attempted to change 
the drive density and the drive was not at BOT. Rewind 
to BOT and retry density change command. 


ILLEGAL PARAMETERS OOMBINATION —— Software attempted to 
set conflicting controller or drive parameters. 


CONTINUE COMMAND ODD ADDRESS OR BYTE COUNT ERROR — An 
odd DMA address or byte count was used with the Read 
and/or Write And Continue command. 


COUNI ZERO -— Software issued the 772 an IJIOPB that 
required a non-zero count, but the count was zero. 
Position commands require a valid count. 


ILLEGAL COMMAND — The Command or Subfunction Code is not 
valid. 
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6.1.1.1 Completion Code Descriptions (continued) 


Code(H) Description 


1c 


1E 


21 


30 


40 


4) 


42 


43 


4a 


45 


46 


ILLEGAL SCATTER/GATHER LENGTH —- The total byte count of 


each element in the link list does not match the total 
number of requested bytes (IOPB byte count). 


NEXT IOPB ADDRESS ALIGNMENT ERROR -— The Next IOPB 
Address did not start on a 16-bit boundary; the 772 does 
not execute the next JIOPB. 


ILLEGAL BLACK HOLE TRANSFER ADDRESS -- During a Black 
Hole Transfer, the data address did not start on a word 
boundary when the 772 was in Word mode (or it did not 
start on a longword boundary when the 772 was in Longword 
mode). 


CORRECTED DATA -- ‘The tape drive error correction 
hardware corrected a single track error during a Read 
command. The 772 sets ERR, but does not stop IOPB 
chaining. 


HARD TAPE ERROR — A data error occurred on a Read or 
Write command. Retry the operation; the tape media may 
be damaged. 


END OF TAPE DETECTED — An EOT marker was passed in the 
forward direction. It is possible to write or read data 
beyond EOT. This status remains valid for all subsequent 
commands in the forward direction. The EOT bit in Status 
Byte 2 remains set for any operation beyond EOT. 


FILE MARK WRITE FAULT — A file mark was not detected 
following a Write File Mark command. 


OPERATION TIMEOUT — ‘The 772 did not complete the 
requested operation within the DBSY timeout window. 


DMAC TIMEQUT — The 772 DMAC controller chip did not 
complete its operation within its timeout. Host memory 
(DTACK) may not have responded in time. This error only 
occurs if EDT is set with a Write Controller Parameters 
command. 


TAPE PARITY ERROR -- The 7/72 detected a tape parity error 
during a Read or Write operation. 


FIFO BUFFER PARITY ERROR — The transfer failed; the 772 
detected a buffer parity error. 
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6.1.1.1 Completion Code Descriptions (continued) 


Code(H) Description 


47 


48 


49 


4A 


4B 


4C 


60 


61 


71 


81 


RECORD LENGTH LONG — The record read was longer than the 
requested record byte count; the 772 only transfers the 
requested count. Readjust the byte count and retry. 


RECORD LENGTH SHORT — The record read was shorter than 
the requested record byte count; the 772 only uses part 
of the read buffer. 


DATA LATE DETECTED — The 7/72 FIFO buffer overflowed 
during a Read or underflowed during a Write command. 


FATAL DMAC ERROR — The DMAC stopped for no apparent 
reason. The count did not overflow, the address did not 
overflow, and there was no bus error. 


VMEbus ERROR -——- The VME BERR* signal was asserted while 
the 772 was bus master. BERR* is asserted by the VMEbus 
timer if either DS1* or DSO* remains active on the bus 
and DTACK* does not go active for longer than the 
allotted time. 


CONTINUE RELOAD ERROR — During a Read/Write Continuous 
operation, the next IOPB did not reach the 772 in time to 
reload the tape byte counter. The 772 completes the 
former transfer as a normal Read or Write operation (IRG 
written). 


DRIVE FAULTED — Certain tape manufacturers report Drive 
Fault errors; this error is the same as Hard Tape error. 


DRIVE NOT READY — ‘The 772 did not receive the Drive 
Ready signal from the selected tape drive. The drive 
cables may be improperly connected. 


FIRMWARE FAILURE -- Flag settings or counter values are 
inconsistent with the firmware routines being executed. 


TRAM CHECKSUM FAILURE -——- The calculated checksum from the 
IRAM and its stored value did not match during the Self 
Test or read parameters command. The parameters that are 
in error are not necessarily in the parameters read by 
this IOPB; they may be elsewhere in the IRAM. Recheck 
all the programmable parameters. Any write parameters 
command resets the checksum, and any subsequent read 
parameters will be error free. A soft bit in the IRAM, 
static, or probing the board with the power on can cause 
this error. See Section 6.7. 
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6.1.1.1 Completion Code Descriptions (continued) 


6.2 


6.2.1 


6.2.2 


Code(H) Description 


82 IOPB ABORTED BY COMMAND — An Abort command terminated 
the IOPB. 
83 IOPB ABORTED BY ERROR — ‘The 772 aborted the IOPB(s) 


because the previous IOPB errored. ‘This code returns all 
IOPBS and IOPB addresses for the unit number and 
interrupt level currently in the command buffer. All 
further AIO requests are blocked until the 772 returns 
all aborted IOPBs. 


90 TAPE REEL WRITE-PROTECTED — A Write operation was 
attempted on a write-protected tape. Install the write 
enable ring and try again. 


91 DRIVE OFF-LINE — The selected tape drivé is off-line. 
Check the drive's on-line indicator and the tape reel. 


AO REVERSE INTO BOT — A BOT marker was detected while 


moving in the reverse direction; tape motion ceases. 


Al FILE MARK DETECTED ON READ — A file mark was detected 
during a Read operation. 


RECOVERY PROCEDURES 


This section describes the Completion Codes and recovery procedures 
in detail. See Section 5 for code numbers. 


Non-retryable Programming Errors 
These errors are caused by illegal use of command parameters and 


are reported back to assist you in debugging the device driver. 
These errors are not retryable; you must change your program. 


Successfully Recovered Soft Errors 


The 772 sets ERR for this class of error, but does not stop IOPB 
chaining. These are status codes only and typically do not require 
any action. These errors are related to the tape media; you may 
want to log them as they may indicate a developing media flaw. If 
retries are enabled, Byte B contains the actual number of retries 
necessary to correct the defect. 
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6.2.3 
6.2.3.1 


Hard Tape Error 


Each drive manufacturer individually defines the cause of this 
error. For many drives this error is a media defect that can 
potentially be corrected with a retry. With retries enabled during 
a Read, the 772 rereads the record with the error up to four times 
before reporting the error. Xylogics suggests always enabling 
retries unless your application requires otherwise. 


If retries are enabled during a Write, the 772 executes the 
following sequence: after encountering a hard error, it reverses 
the tape to the beginning of the record in question and issues an 
Erase command (which erases three inches of tape), and retries the 
Write. The controller repeats this sequence four times, erasing up 
to 12-inches of tape. It is still possible that the hard error is 
beyond the retry; at this point you must issue individual Erase 
commands until the error is erased (see Figure 6-1). (Use this 
procedure if retries are not enabled.) The 772 "sees" an erased 
section of tape as an interrecord gap; it is progranmer- 
transparent. 


SOFTWARE ISSUES ERASE COMMANDS 


| —_—__—___—_> 
“PEELE, = _ 
a ad 


772 RETRIES 4 TIMES. EACH "E" SOFTWARE ERASES OVER 
REPRESENTS 3 INCHES OF TAPE. BAD AREA AND WRITES 
RECORD SUCCESSFULLY 


Figure 6-1. Write Error Beyond Retry 
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6.2.3.2 


6.2.3.3 


6.2.3.4 


6.2.3.9 


End of Tape Detected 


This is one of the lowest priority Completion Codes; there is also 
a bit that indicates EOT. EOT is the physical end of tape marker; 
it indicates that all further Read or Write operations should be 
terminated or limited to a small number. Since there is approx- 
imately 25-feet of tape remaining after EOT on which you can 
record, only a small number (and size) of records can be handled. 
Be careful, the 772 cannot keep you from running off the end of the 
tape reel. Although the 772 reports an error when it encounters 
EOT, it completes the entire transfer (which means your record is 
straddling the EOT marker). Once past EOT, the 772 completes any 
command successfully (unless another error condition occurs) with 
an EOT error status. Since EOT does not necessarily indicate the 
end of recorded data, Xylogics suggests writing at least two 
consecutive file marks to indicate the logical end of tape. 


File Mark Write Fault 


The 772 returns this code if a hard error condition occurs during a 
Write File Mark operation. Like writes, this operation can be 
retried up to four times by erasing. Retry failures are unlikely, 
unless the media is in very poor condition. 


Operation Timeout 


An Operation Timeout indicates that the signal Data Busy (DBSY) 
from the tape drive did not go active within the controller's set 
time period. Retry the operation. If the same error occurs, it is 
possible that the tape drive is malfunctioning. Most non-cached 
tape drives time out DBSY within .25 seconds; if an Operation 
Timeout occurs with this type of drive it is likely the drive has a 
problem. Tape drives with cache memories can also cause this 
error. These drives delay Data Busy when flushing the cache or 
utilizing retry algorithms, causing the 772 to time out. Setting 
the 772 Data Busy Timer to a higher value avoids this condition. 


DMAC Timeout 


The 772 DMA controller timed out during the tranfer. ‘The same 
rules that apply to the VMEbus error apply to the DMAC Timeout (the 
difference is the 772 is doing the detection, not the bus monitor. 
See Section 6.2.3.12). 
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6.2.3.6 


6.2.3.7 


6.2.3.8 


6.2.3.9 


Tape Parity Error 


The tape drive reported that one of the bytes of data transferred 
was. bad. The 772 completed the entire transfer but the data 
integrity is suspect. Parity errors can be caused by marginal tape 
media or foreign matter on the media or heads. Xylogics recommends 
first rereading/rewriting (or just retrying) the record. MI£ the 
error persists, try cleaning the tape drive heads. 


Many tape manufacturers enable read data and parity during Write 
commands. This is not a problem, except certain manufacturers 
define these lines as invalid during Write operations. In this 
case, enable the IPOW bit with a Drive Parameters command; this 
turns off parity checking during Writes. 


FIFO Parity Error 


The 772 detected a parity error during a data transfer to or from 
the FIFO buffer; it completes the entire transfer, but the data 
integrity is suspect. Retry the transfer. If the error persists, 
it is likely there is a FIFO hardware malfunction. 


Record Length Long 


This error only occurs during Read operations. The record being 
read is larger than the byte count issued in the command. The 772 
can report this error in both the Completion Code and Tape Status 
Byte 1 (RLL). Since the 772 only transfers the requested number of 
bytes, you must reread the entire record. First, position the tape 
to the beginning of the record with a Skip Record Reverse command. 
Next, readjust the byte count to the maximum allowable byte count 
because you may not be sure of the record's size. Issue the 
command, and expect to get a Record Length Short error (make sure 
no other error occurs). The actual count byte field indicates the 
size of the record transferred. This helps you determine where the 
next buffer begins. Use this procedure when reading tapes 
containing records of unknown size; it won't work if the record is 
larger than 64KB (then you must use the Read Continuous command). 


Record Length Short 


This error only occurs during Read operations. ‘The record being 
read is smaller than the byte count issued in the command. The 772 
can report this error in both the Completion Code and Tape Status 
Byte 1 (RLS). Since the entire record was read, it is not 
necessary to retry the Read operation. You may want to adjust the 
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6.22369 


6.22310 


6.2.3.1] 


Rev. B. 


Record Length Short (continued) 


data address of the next Read to keep your buffers contiguous, or, 
if all the records are of similar size, readjust the byte count 
field to match the actual count. If you know the byte count is 
correct, and the 772 reports a Record Length Short error, the tape 
heads may need cleaning. 


NOTE 


If the record read contains an odd number of bytes, the 
last byte transferred is duplicated and written to memory. 
This is done intentionally due to certain hardware 
requirements. Writing this extra byte should not affect 
you (you initially allocated a larger buffer and the 772 
does not report this byte in the actual count). 


Data Late Detected 


During a Read operation, this error indicates that the 772 FIFO 
buffer overflowed. This means the DMA was unable to keep up with 
the tape drive's data rate. The entire record must be reread if 
this error occurs: position the tape to the beginning of the 


record with a Skip Record Reverse command, then reissue the Read. 


During a Write operation, this error indicates that the 772 FIFO 
buffer underflowed. This means the 772 received a Write command, 
but the data from memory did not arrive in the FIFO, and the tape 
Started; in this case, set the Write Wait DMA (WWD) bit with a 
Write Controller Parameters command. Setting WWD delays starting 
the tape until data reaches the FIFO. Another condition could be 
that some, but not all, of the data for the record did arrive in 
time (before the FIFO emptied). Either way, the 772 writes same 
data to tape, requiring a Skip Reverse before retrying the Write. 


If this condition persists, there is a bottleneck occurring on the 
DMA. This happens if the 772 DMA throttle value is too small, or 
if other DMA devices tie up the bus. 


Fatal DMAC Error 


The DMAC reported a 16-bit address overflow when not expected or 
did not overflow when expected. This is a 772 malfunction. Retry 
the operation. If the error persists, issue a Controller Reset and 
retry the operation. If a Controller Reset does not clear the 
condition, then there may be a hardware malfunction. 
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6.2312 VMEbus Error 


6.223.213 


6.2.4 
6.2.4.1 


6.2.4.2 


6.2.4.3 


6.2.9 
6.2.5.1 


Rev. B. 


A VMEbus error occurred while the 772 was bus master. The bus 
transfer did not complete because the Address, or Address Modifier 
was wrong (no memory at the address specified), or a longword 
transfer was attempted to word memory. Retry the operation. If 
the condition persists, issue a Controller Reset and retry. If a 
Controller Reset does not clear the condition, then a system reset 
is necessary or same other piece of system hardware is failing. 


Continue Reload Error 
Software's inability to keep commands coming in before they are 
necessary causes this error. The 772 treats the last successful 


Continuous command as a standard read or write. This error should 
not occur if Continuous commands are properly chained or queued. 


Hard Errors Requiring Reset and Retry 


Drive Fault 

Certain drive manufacturers report this error; the tape drive is 
reporting a malfunction. Issue a Drive Reset command and retry the 
Operation. If the error persists, consult the drive manual for 
possible causes and diagnostics to run. 

Drive Not Ready 

The selected tape drive is not ready. Issue a Drive Reset command 
and retry the operation. If the condition persists, verify the 
drive is loaded, on-line, and that the cables are good, and 
connected properly. 

Firmware Failure 

Retry the operation. If the error persists, it is possible that 
the EPROM firmware is corrupt. 

Miscellaneous Errors 

-IRAM Checksum Error 

If this error occurs during a Read Controller or Read Drive 
Parameters command, then the IRAM has not been initialized or the 
battery is failing. First try initializing the IRAM with the 
parameters you require. If the error persists, the IRAM may 
require replacement. 
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6.2.5.2 


6.2.963 


6.2.6 


6.2.6.1 


6.2.6.2 


6.3 


IOPB Aborted by Command 


The 772 aborted the IOPB by command. For example, software may 
determine that a particular Unit Number is continuously failing and 
terminate any further commands to that unit. 


IOPB Aborted by Error 


The 772 aborts this IOPB because the previous IOPB errored. ‘the 
772 returns all IOPBs and IOPB addresses for that Unit Number and 
interrupt level with this code. Initiate a recovery procedure for 
the initial IOPB hard error, reinitialize the IOPBs aborted by 
error, and restart the chain. 


You're Lost 


You are not where think you are on the tape or you do not know the 
record format on the tape. 


Reverse Into BOT 


The BOT marker was encountered during a Reverse command other than 
Rewind. Tape motion stops and the tape remains at BOT until the 
next Forward or Unload command is issued. Most likely, you have 
fewer records or file marks than you thought. Since no data 
transfers take place in reverse it is not necessary to retry. 


File Mark Detected On Read 


An unexpected File Mark was detected during a Read or Space Records 
command. Most likely, you did not know how many records were in a 
particular file. No retry is necessary. 


IGNORING ERRORS 


Certain applications require ignoring errors when Reading or 
Writing data. Typically, this is done in real-time data collection 
applications where the controller and software do not have the time 
to handle tape errors. 


If the Ignore Errors feature is enabled, the 772 does not report 
Corrected Tape, Tape Parity, or Uncorrectable Tape errors on Read 
or Write commands. The 7/72 reports the number of errors 
encountered in a record in special byte fields if AUD is enabled. 
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6.4 


6.5 


6.6 


FATAL ERROR CODE DESCRIPTIONS 


Code Description 

EO TRAM CHECKSUM FAILURE -—- The IRAM checksum did not 
match the expected checksum following bus 
initialization. 

El—-EF POWER-UP SELF TEST — The 772 failed the Power-up Self 


Test. See Section x.x. 


FO IOPB CHECKSUM MISCOMPARE -- The generated checksum did 
not match the appended checksum. See Section 8.8. 


Fl IOPB DMA FATAL -- The 772 did not complete the DMA 
within the prescribed timeout period. 


F2 IOPB ADDRESS ALIGNMENT — The IOPB address did not 
start on a 16-bit boundary. 


F3 FIRMWARE ERROR —- Flag settings or counter values are 
inconsistent with the firmware routines being executed; 
the IOPB cannot DMA the appropriate error status. 


F4 CABLE TEST FAILURE -— The loopback cable test failed. 


F5 ILLEGAL MAINTENANCE MODE TEST NUMBER — The command is 
invalid, or the Maintenance mode jumper is not in. 


F6 ACFAIL ASSERTED -— ‘The VMEbus’ signal ACFAIL is 
asserted, cauSing the 772 to stop. Correct the problem 
asserting ACFAIL and then reset the 772. 


ERRORS DURING CHAINED OR QUEUED OPERATIONS 


The 772 handles chaining and queueing errors in the same manner. 
If an error occurs, all further IOPBs are marked with Abort On 
Error. Any further action depends on your retry algorithms. 


ABORTING 


Abort commands and Abort errors inhibit AIO processing; no further 
IOPBs can be added to the queue. The 772 processes the AIO queue 
normally, but aborts IOPBs that are on the same drive at the abort 
interrupt level; it marks these IOPBs as aborted by command or 
aborted by error. The 772 re-enables AIO processing after 
completing the AIO queue and the main IOPB chain. 
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6.7 TRAM CHECKSUM 


Each time the 772 executes a read parameters command, it compares a 
generated checksum with the stored checksum. This checksum 
encompasses the area that contains all the parameters, not just the 
ones being read. When this error occurs, the checksums did not 
Match; rewrite or check all the parameters. Any write parameters 
command generates and stores a new checksum. 


6.8 ERROR REPORTING HIERARCHY 


Figure 6-2 illustrates the 772 firmware error checking path(s). 


START 


ODD IOPB ADDR ALIGN. 
Y are ae 
FATAL ERROR Hah Stl Sard 
1OPB OMA FATAL 
N 
Y 
IOPB DECODE 
ERROR 
N 
ote DENSITY CHG. NOT AT BOT 
y _ |DRIVEOFF-LNE 
UNOORFECT. TAPE ERROR 
ORIVE NOT READY - 
WRITE-PROTECTED 
SCAT/GATH Y VVEBUS ERROR 
iOPB Eero 
Eero 7 


OPERA 
DATA DMA ill rT TAPE ERROR 
i es 


FATAL DMAG ERR. FILE MAPK DETECTED ONEAD 
FIFO PARITY ERR. Se FILE MARK WRITE FAULT 
TOPE EOT DETECTED 
CORRECTEDERROR 
UNCORRECTABLE T 


Figure 6-2. Error Reporting Hierarchy 
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SECTION 7: A TUTORIAL IN PROGRAMMING THE 772 


7.0 GENERAL 


This section describes programming the 772 for basic use. ‘This 
tutorial programming procedure begins with a single NOP IOPB and 
progresses to Normal Read and Write commands. Each section builds 
on the previous section's information. 


Tol NO OPERATION (NOP) 


The NOP command allows you to become familiar with the 772 
programming interface. 


LZALOMMAND CODE = 0 VW 


00 00 
00 04 
00 A3 
00 00 


| Cee} | oo [UNIT ] 00 00 

| LINKLSTLENGTH] 02 | 02 
LLL MER RUPT VEC) ORVIYYYLL, ©) 
ei ae 
ey, 
oe ee 
: oT 
| | 00 


‘i 
| 
= 00 00 


DATA OR LINK ADDRESS 


DATA OR LINK ADDRESS LOW ee a6 


oye ee 
: “ aRarenaee 00 
00 00 
00 00 
00 00 
00 00 


ZL, Fo9 To ee 2" 


Figure 7-1. Sample NOP IOPB 
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71.1 


71.2 


7.1.3 


7.1.4 


721.5 


Allocating Memory For An IOPB 


First, allocate space in host memory to store the IOPB. ‘This 
allocation is a function of the operating system or the currently 
executing program. Next, set up the IOPB to execute a simple NOP 
command (see Figure 7-1). 


Point the 772 to the JLOPB 


The IOPB is now in host memory. Point the 772 to the IOPB by 
loading the IOPB address and address modifier into the appropriate 
772 registers. Make sure the address compensates for any memory 
mapping that may be done between virtual and physical addressing in 
your system. The 772 looks for the IOPB at the physical address to 
which the registers point. 


NOTE 


Always access the registers in Byte or Word mode. Register 
bytes are ordered low to high (unlike IOPB bytes which are 
ordered high to low). 


The 772 now points to the IOPB in host memory. Setting the AIO bit 
in the CSR directs the 772 to process the IOPB. 


i12 Operation 
At this point, the 772 performs the following functions: 


Clears AIOP and sets BUSY. 

Reads the IOPB from host memory. 

Decodes the command. 

Performs the operation (NOP). 

Sets the DONE bit. 

Updates the IOPB. 

Puts the completed IOPB's address into the registers. 
Sets RIO. 

Clears BUSY. 


WONHA UM PWN EE 
e 


Command Completion 


Software has been polling RIO (Since interrupts are not enabled 
[Interrupt Level = 0]). Software knows that the 772 sets RIO when 
it is done. Software should get the completed IOPB's address from 
the registers, and then clear RIO. This completes the NOP command. 
(Do not poll the DONE bit in the IOPB. The 772 sets DONE while the 
rest of the IOPB is still updating.) 
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7.1.6 


72 


7.21 


Returned Values 


DONE is set in the returned IOPB. Status Bytes 2 and 3 reflect the 
status of Tape Drive 0. 


READ CONTROLLER PARAMETERS 


Next, implement the Read Parameters command with a Controller 
Parameters subfunction (see Section 5.7.1). This command returns 
several controller parameters in the updated IOPB (see Figure 7-2). 


Execute the IOPB 


Set up the IOPB in host memory; point the 7/72 to the IOPB. Setting 
AIO directs the 772 to begin executing this IOPB. 


READ CONTROLLER PARAMETERS 


a ae SENT | RETURNED 


A EP DP a a a a A 


VE ALLOMMAND CODE=6 V7) 06 | 46 


NT SSE 7 YY 7 ‘ 


[l0PB CHECKSUM aaa ie ech 00 00 
[lOPB CHECKSUM LOW J. || 00 00 


WLLL, favtrecution (ee ate UU) ene 


Figure 7-2. Sample Read Controller Parameters IOPB 
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7202 


722.3 


7.3 


7231 


112 Operation 


The controller operation changes slightly from the example in 
Section 7.1.5: 


The 772 performs the Read Controller Parameters operation. ‘The 
controller gets the parameters from its internal store, and puts 
them in the proper IOPB locations. The 772 fully updates the IOPB, 
including the returned values. | 


While reading the controller parameters, the 772 calculates a new 
Internal RAM (IRAM) checksum and compares it to the previous value. 
The 772 returns the appropriate Completion Code if the values do 
not match. 


The Returned IOPB 


The values in the returned IOPB describe the last setting of the 
software-programmable parameters. Determine if each value works 
for your application (see Section 5.7). After making any necessary 
changes, write the parameters back to the 772. 


Specific bytes have known values. The Controller Type byte 
contains a 72H; the PROM Part Number bytes contain 21H and 38H. 
See Section 4.3 for more information. 


WRITE CONTROLLER PARAMETERS 


Next, write the controller parameters. Xylogics recommends reading 
the current parameters, modifying the ones in question, and then 
writing them back to the 772. This method allows you to change 
only those parameters that affect your system (see Figure 7-3). 


112 Operation 
The 772 executes the IOPB slightly different than in Sections 7.1.5 
and 7.2.2: 


The 772 performs the function by taking the values of all 
programmable parameters out of the IOPB and setting the appropriate 
flags and variables in its internal RAM, 


The 772 also calculates a new checksum in the IRAM and stores it 
for use in the next reading of any parameters (see Section 5.6). 
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72301 712 Qoeration (continued) 


WRITE CONTROLLER PARAMETERS 


Pe Toe oe ee a ee a oe 


SENT 7} RETURNED 


ie ee (ta || | Ea) W/o yyy roe 
TM eorecstioncooe MMMM © «| 3 
Z AWMTERRUPTLEVELT ZA 02 | 02 
: 66 66 
‘ fo | Ges) | feot] [ners] [ator] |] ez | 2 
Ill" ss Irv 
oD 00 00 
10 00 00 
11 oc 00 
12 00 00 
13 00 00 
ee SSH SEEPS MEE s ee 5 : 00 00 
is | 00 00 
16 00 00 
Mcrae Tr oe 
18 bess: 22 rae ene : q 00 00 
1 oe ee | Se eD oo 00 


7] Optionally TRIUUAANUNAT Returned 
|) Required Value 


Witt ines ee 


Figure 7-3. Sample Write Controller Parameters IOPB 


7.4 - READ/WRITE DRIVE PARAMETERS 


The Drive Parameters commands allow you to configure the 772 to 
your drive's parameters. Sections 5.6.1 and 5.7.1 describe the 
configuration variables that may be modified with these commands. 
The operation is similar to the Controller Parameters command (see 
Figure 7-4). 
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74.1 772 Operation 


First, issue a Read Drive Parameters command; this indicates the 
current drive parameters for the selected unit. It is not 
necessary to issue the Write Drive Parameters command if the 
returned parameters match the drive you are using. 


7.4.2 Write Drive Parameters 
On a Write Drive Parameters command, the 772 performs an operation 
similar to that of the Write Controller Parameters command. Use 


the Write Drive Parameters command to globally change drive 
parameters on a per unit basis. 


WRITE DRIVE PARAMETERS 


|, EEE Se AEE ZZ | 


00 00 


01 PHER | coxeemes arerrerh rece nit eics sidel Gans==="=5== sani ands eeCRaSENUGELabaro==<seue= 
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O35 Ue UY be ed UU er UU eee! UL Beer UY rel HE errr 
20 20 
04 
01 01 
0) ee LY Me we we a oe 
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TEE: 30 30 
08 [sb Rd pee 
A? A? 
09 pi creer rd eho toro 
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lO] a EStUESHUESSESITCSUUUELERRRWECEESES. .oscecooeooseocoooseeeaosoweeeoesoeoovscouseccosoescesoeedUel 00 00 
of | LERIOJ | 0 Fee ee NEXT 00 00 
ie 7 7F 
fei 00 00 


([TOPB CHECKSUM HIGH }: 00 00 
[TIOPB CHECKSUM LOW] Secs) 00 00 


LLL, Fase oa a 
Figure 7-4. Sample Write Drive Parameters IOPB 
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7.9 


WRITE DATA 


following 
This subsection describes a Write operation, and the 
subsection describes reading back the data. Allocate space in host 
memory for the buffer, and set up a data pattern in this buffer; an 
incrementing count in the buffer will suffice. 


j d. The tape 
Up to this point, the tape drive has not been accesse 
should be at BOT. Issue a Write command of 65,535 bytes (see 


Figure 7-5). 


WRITE DATA 


oo {IEERRS, SIE yf fren) | a = : 
. ee eee «: | 
6 AM | 86 : 
a7 eee a 
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senile UATE Returned 
Required Value 


Figure 7-5. Sample Write Data IOPB 
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7 Del 


7 D502 


7.6 


7.6.1 


112 Operation 
The 772 operation is similar to the previous examples; the 


differences are in DMAing data into the FIFO, and writing data to 
the tape. 


The 772 starts the DMA from host memory to the FIFO after issuing 
the Go command to the tape drive. The tape starts first due to 
mechanical delays. | 


NOTE 


Mechanical delays may not be present and Data Late errors 
May occur when using a cache tape drive. In this case, do 
not start the tape until the DMA reaches the FIFO. This is 
enabled by WWD in the Controller Parameters IOPB. 


The 772 transfers data from the FIFO when the tape is ready to 
receive it. The 772 supplies the tape interface with a data byte 
for each tape drive-supplied write strobe. When the last byte is 
transferred, the 772 sends Last Word to the tape, terminating the 
transfer of that record. At this point, the tape drive writes an 
interrecord gap. 


Command Completion 


The command is complete as soon as the tape drive drops Data Busy | 
(DBSY) . The 772 checks for error conditions, puts the ending 
values into the internal IOPB, and performs an appropriate update. 


READ DATA 


This subsection describes reading back the data and verifying it. 
You must allocate a data buffer for the 772 to write the data in 
memory. After allocation, use the Write Data command to fill the 
buffer with a known pattern that differs from the expected data. 
Read the record you wrote in Section 7.5. First, issue a Rewind or 
Space Records Reverse command with a count of 1 to put yourself in 
front of the record. Now issue a Read command with a count of 
65,535 (see Figure 7-6). 


112. Operation 


The 772 treats this command like the previous operations, except in 
the way it writes the data into the FIFO and to host memory. 
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7.6.1 772 Operation (continued) 


The tape drive supplies the tape interface with a data byte for 
each tape drive-supplied read strobe. The 772 then transfers the 
data into the FIFO. As soon as data is available, the DMA 
controller DMAs the data from the FIFO to host memory. The 
transfer is done when the DMA controller completes the DMA. 


READ DATA 


TBSSET TL TECSaT TEST WHE EO sent | RETURNED 


ef 


[OONE| || [CHEN] [son] WAZA COMMAND CODE = 2 Www] 02 42 


LAT PE MT MP PP a a 


EEE FF 00 


LEE. —— 00 00 
®@LLL ELL ALLE co} et 


a cas oe An a oc: 00 
BOT oe Soo eee Citi =. 00 
Len Biegets oes | 00 00 


Witla mowee ao 7 I Verve 


\ 


Figure 7-6. Sample Read Data IOPB 
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726.2 


7.6.3 


7./ 


7.8 


Command Completion 


The 772 completes the command when the DMA to memory is complete. 


Verify Data 
First, make sure the buffer was modified. If it was not modified, 
either an error occurred, or software specified the wrong buffer 


address. Next, compare the data written with the data read; they 
should match. 7 


LARGE RECORD TRANSFERS 


You can repeat the steps in Sections 7.5 and 7.6 using various 
record sizes. The 772 can transfer records sizes from 1 to 65,536 
bytes. Be sure to allocate enough buffer space for the increased 
record size. 


SUMMARY 


This section was an excercise in testing the 772's functionality in 
your system. The steps are basically the same when the software 
Griver controls the 772. (Operating systems always allocate the 
buffers. ) 
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8.0 


8.1 


8.1.1 


8.1.2 
8.1.2.1 


SECTION 8: 772 SPECIAL FUNCTIONS 


GENERAL 


This section describes how to implement the various 772 special 
functions. 


MAINTENANCE MODE 


Firmware supports a non-IOPB driven Maintenance mode. It allows 
you to perform basic testing within the 772 by setting Control bits 
in the CSR and entering the desired test number and data through 
the address registers. This mode also provides a window through 
which internal registers may be examined or modified. 


Register Use in Maintenance Mode 


The function code in the Test Number Register determines whether or 
not the 772 uses the Input Data Byte and Output Data Byte 
Registers. You should be familiar with the Control and Status 
Register before reading this section (see Section 3.3). 


; oti 


Test Number or Function Code 
Input Address Low 

Input Address High 

Input Data Byte (If Required) 
Output Data Byte (If Required) 
Control and Status Register 
Fatal Error Register 


: 


OWoNAUWE- 


Table 8-1. Register Use in Maintenance Mode 


Maintenance Mode Protocol 
Executing a Maintenance Command or Entering the Maintenance Mode 


First, set the Maintenance Mode (MM) and Add IOPB (AIO) bits. This 
forces entry into the maintenance kernel; the kernel initializes 
the CSR and Poll mask and sets the Remove IOPB (RIO) bit. Next, 
set the Clear RIO (CRIO) bit. 


The kernel expects the Input Address Low Register to contain a 
maintenance test number or function code for execution. Data may 
be expected or may be returned (see register layout). 
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8.1.2.1 


8.1.2.2 


8.1.2.3 


8.1.2.4 


Executing a Maintenance Command or Entering the Maintenance Mode 
(continued) 


BUSY and AIO are configured for polling. Setting the Register 
Maintenance Mode (RMM) bit selects the register image test; 
Clearing BUSY returns control to the maintenance kernel. 


AIO causes the maintenance firmware to read and decode the command 
string from the Input Address Registers. After successfully 
decoding the command string, the firmware echoes it (command, 
address, and data) to the Output Address Registers and clears AIO. 
This acknowledges receipt of and attempts to execute the requested 
command. After completing the requested command, the 772 updates 
the Output Address Registers with test-pertinent data and sets RIO. 
The AIO/RIO protocol is identical to Normal mode. 


RIO indicates the end of firmware involvement and valid contents in 
the Output Address Registers. 


Since each test and its expected results are different in nature, 
the Output Address Registers hold the test result information 
(address, data, etc.). In any case, firmware sets RIO upon command 
completion; it sets the Fatal Error bit if a failure occurs or if 
host software issues an illegal command. 


Exiting the Maintenance Mode 


To exit the Maintenance mode, clear MM and RIO, and set AIO. This 
returns control to the Normal mode kernel. The 772 acknowledges by 
setting RIO. 


Diagnostic Considerations 


The Input/Output Address Register Verify is the first test the 
diagnostic should execute. 


Firmware flags the Power-up Test failures by setting the Fatal 
Error bit while leaving the Maintenance mode bit set. Firmware 
saves the Self Test error numbers internally until it verifies the 
Input and Output Address Registers. 


Register Tests 
You must request entry into the Maintenance mode to invoke the 


Register test. After firmware acknowledges the request, you should 
set RMM. BUSY remains set during this test. 
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8.1.2.4 Register Tests (continued) 


8.1.2.5 


8.2 


8.2.1 


8.2.2 


NOTE 


You must enter the Maintenance mode as a separate 
step because the Normal mode firmware does not 
allow setting BUSY (defined as RMM when Maintenance 
mode is enabled). 


Setting the Input Address Registers, followed by AIO, Signals 
firmware to copy the data to the Output Address Registers. 
Firmware sets RIO when it completes the copy. Host software should 
then clear RIO. 


Clearing Busy exits this test and returns the 772 to Maintenance 
mode. 


Test Variables 


Some of the internal tests require the address and data to perform 
their particular function. On-board memory has Space allocated for 
this data. These locations are loaded with default values for 
initial use. However, you may alter these variables through the 
Manual mode. (As the internal tests are defined, the protocol and 
results expected will be made available.) 


MULTIPROCESSOR SUPPORT 


The 772 has several options that make multiprocessor environments 
easier to support: the programmable interrupt vector, interrupt 
level, register address modifiers, and busy semaphore. 


interrupts 


Each IOPB specifies the interrupt level and vector for that 
command. In a multiprocessor environment, each processor can have 
its own assigned interrupt level and vector. 


Register Busy Semaphore 
RBS allows multiple processors to share the registers without 


colliding. Hardware supports the Register Busy Semaphore (RBS) 
bit. The register access protocol involves reading the CSR. 
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8.2.2 


8.2.3 


8.3 


8.3.1 


8.3.2 


8.3.3 


Register Busy Semaphore (continued) 


Tf RBS is clear, the host has control of the register, and retains 
control until it clears RBS in the Control Register. If the first 
read to the Status Register indicates that RBS is set, then another 
host has control of the register and this host must wait until RBS 
clears. 


The 772 sets RBS immediately after a host reads the CSR. If a host 
attempts a read, and RBS is clear, then the 772 sets RBS; any 
successive reads by other hosts will "see" that RBS is set. When 
the host using the registers is done, it must clear RBS. Clearing 
RBS and setting AIO can occur in the same register write. Clearing 
RBS without having control of the registers violates the register 
protocol. 


Address Modifiers 


The address modifiers can be used to asSign Separate address space 
for each of the processors. | 


SOFTWARE CONTROL 


The 772 has many parameters that can be modified by software 
control. The parameters can be set in bulk by having an IOPB with 
all the correct information, and executing a Write Parameters 
command. 


Modifying a Single Parameter 
The best method of modifying a parameter is to first execute a Read 
Parameters command for the associated parameter block, modify the 


Single parameter and then write the parameter block back to the 
controller. 


Modifying a Group of Parameters 


Use the same method as in Section 8.3.1, but modify your multiple 
parameters. An alternate method does not require prereading the 
parameters, but does require setting all the parameters in the 
specific IOPB. The 772 sets all parameters to the new values 
contained in the IOPB. 


Parameter Reference Point 
After the 772 is working as intended, read the parameters and save 


the information (in an appropriate parameters table) for future 
use, 
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8.3.4 


8.345 


8.4 


8.4.1 


Setting Parameters at Boot Time 


It 1s not necessary to reload the parameters at each boot since the 
parameters are stored in a battery backed-up RAM. It is a good 
idea to reload them each time if you are not sure how the board was 
last used. 


Validate Current Parameters 


The parameters are all protected by a checksum, and any Read 
Parameters command performs a checksum test. The Read Parameters 
terminates with an error if the generated parameter checksum is 
different than the stored checksum. See Section 6 for more detail 
on the IRAM Checksum error. 


SCATTER/GATHER 


The 772 is able to execute Scatter Reads and Gather Writes. Ina 
Scatter Read, the 772 transfers the data from tape to up to 32 
blocks of memory. Gather Write gathers data from up to 32 blocks 
of memory and writes it to the tape as one record. ithe size of 
each memory block must be an even byte count and the total count 
must be less than or equal to 64K-bytes long. ‘The blocks may be 
scattered throughout memory. 


Scatter/Gather Link List 


You can determine the length of the linked list by multiplying the 
number of elements in the list by eight (each element is 8—bytes 
long). All data addresses must be on word boundaries, and the byte 
count must be even. For reads and writes, enter the number of 
elements in the linked list into bits 3 through 7 of IOPB Byte 6. 


1 00-01 Byte Count (Multiples of 2) 

02 Reserved 

03 Data Address Modifier 

04-07 Data Address (Word Boundaries Only) 
2 08-09 Byte Count (Multiples of 2) 

0A Reserved 

OB Data Address Modifier 


OA-OD Data Address (Word Boundaries Only) 


N XX—XX Data Address Modifier 


Table 8-2. Scatter/Gather Link List — 


Rev. B. August 15, 1987 98 


XYLOGICS 772 Tape Controller User's Manual 


8.4.1 


8.4.2 


Scatter/Gather Link List (continued) 


0 32 
1 1 
2 2 
9 9 
A 10 
B 11 
1E 30 
1F 31 


Table 8-3. Link List Field Values 


Setting Up a Scatter/Gather Transfer 


The Data Address and Modifier bytes in the IOPB should now point to 
the start of the linked list. The linked list length field should 
give the total number of element descriptors on the list. 


Elements of memory descriptors comprise the linked list. Each 
element describes the starting address and the length, in bytes, of 
the memory block. 


The IOPB and linked list in Figure 8-] illustrate a Read transfer 
to 6 blocks of memory. ‘The record size in this case is 528 bytes; 
we are transferring 3 records of information. (‘he 772 transfers 
the first 16 bytes of data from each record to a separate data 
buffer. It scatters the bulk of the data, 512-bytes per record, 
into memory as 3 blocks having 512 bytes each. 


Set SGM and execute the IOPB in Figure 8-l. 
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8.4.2 


8.4.3 
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Setting Up a Scatter/Gather Transfer (continued) 


SCATTER / GATHER READ COMMAND 


ae eee ee ee ee ee a 
00 | ERRS| DONE] CHEN] SGM | COMMAND 


01 COMPLETION CODE 


oz (_HER | cer | ris [ Rut | rmx[pem | ror | wrt] - 
03 


04 SUBFUNCTION 


of oer To [rr - 


06 
07 
08 | COUNT HIGH 
09 | COUNT Low 
LAST RECOVERED/IGNORED ERRORS 

COUNT OF RECOVERED/IGNORED ERRORS 

ACTUAL COUNT HIGH 

ACTUAL COUNT LOW 

DATA OR LINK ADDRESS MODIFIER 

| Q | NEXT IOPB ADDRESS MODIFIER 
DATA / LINK ADDR HIGH 

DATA / LINK ADDRESS 
ATA / LINK ADDRESS 
ATA / LINK ADDR LOW 
NEXT IOPB ADDRESS HIGH 
NEXT IOPB ADDRESS 
NEXT IOPB ADDRESS 

NEXT IOPB ADDRESS LOW 

IOPB CHECKSUM HIGH 

IOPB CHECKSUM LOW 


Oo Oo 
oO 


O 
omMWraI DU BW KF ~*~ CO M1 MH 


© 


oO 


oO 


_— 


— 


= 


Figure 8-l. 


712 Operation 


12H 
OH 
OH 
OH 
OH 
02H 


= 30H 


OH 
O6H 
30H 

OH 
02H 
O1H 
04H 
02H 

OH 

OH 

OH 

OH 


= 19H 


OH 
OH 
OH 
OH 
OH 
OH 


Scatter/Gather Transfers 


00020H 


00-01 
02-03 
04-05 
06-07 
00-01 
02-03 
04-05 
06-07 
00-01 
02-03 
04-05 
06-07 
00-01 
02-03 
04-05 
06-07 
00-01 
02-03 
04-05 
06-07 
00-01 
02-03 
04-05 
06-07 


LINK LIST 


DAL=2200H | 
T8c=0010H | 


DAL= 1020H 


baL=2400H | 


The 772 proceeds as if doing a normal read until it starts the data 


transfer into memory. 


The contents of the linked list now controls 


the DMA processor; it gives the DMA processor the byte count and 


address for each element on the list. 


°] 


each element on the list. 


100 


The DMA processor takes the 
ta out of the FIFO and transfers it to memory as described in 
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8.5 


8.6 


8.7 


DMA THROTILE / THROTILE DEAD TIME 


The 772 always transfers IOPBs in 16-bit Word mode; it uses the 
last specified values for the throttle and throttle dead time. 


Host software can set the Throttle Dead Time (TDI) field in the 
Controller Parameters IOPB. This value defines the time that the 
772 waits before attempting to regain control of the bus between 
throttle bursts. There are four valid TDT values. 


TDI Value Time 


0 microseconds 
3 2 a 
6.4 . 
12.8 


W NF © 


Table 8-4. Throttle Dead Time Values 


BLACK HOLE TRANSFERS 


In certain applications, the data to be transferred has to go toa 
Single memory location. This single location is usually a graphics 
controller with a single port on the bus. ‘The Normal DMA mode 
increments the bus address on each transfer so that the data is put 
into contiguous memory space. When Black Hole Transfers are 
implemented, the 772 does not increment the bus address between 
each data transfer. 


Any transfer that includes a DMA to a single location should have 
BHT set in Byte 5 of the IOPB. ‘This causes only the data transfer 
portion of the command to not have its bus address incremented. 
The IOPB DMA still occurs in Normal mode (i.e., the 772 increments 
the address). 


The data address must be properly aligned: word aligned for word 
transfers, and longword aligned for longword transfers. ‘The 772 
cannot do dynamic mode switching with this option. 


PRIORITY IOPBs 
The 772 processes Priority IOPBs in advance of any other IOPBs in 


its queue. This feature works on both a single IOPB and an IOPB 
chain. 
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8.7.1 


8.7.2 


8.7.3 


8.8 


8.9 


Executing a Priority IOPB 

To execute a priority IOPB, set PRIO in both the IOPB Address 
Modifier Register and the Next IOPB Address Modifier byte in the 
IOPB. Set the rest of the IOPB Address Registers to point to the 


IOPB (do not reset PRIO in the Address Modifier Register when 
loading it). Set AIO as you normally would. 


Executing a Priority Chain 
To execute a Priority chain, follow the directions in 8.7.1. All 


IOPBS in the chain must have PRIO set in the Next IOPB Address 
Modifier byte. 


712 Response to a Priority IOPB (Chain) 


The 772 finishes executing the IOPB that is currently active (if 
any). The next IOPB to execute is the priority IOPB (or the first 
in the priority chain). If the 772 starts a chain of priority 
IOPBs, it completes one at a time until it completes the chain, and 
then goes back to processing the IOPBs in its queue. All IOPBs in 
a priority chain must have PRIO set. 


IOPB CHECKSUM 


While debugging the driver, you may choose to append the checksum 
to the IOPB. ‘The checksum is the sum of Bytes 0 through 17 in the 
IOPB, and is expressed as a 16-bit quantity. The 772 generates a 
checksum with the data from the IOPB and compares it to the 
appended checksum; a miscompare causes a fatal error. If AUD and 
ICS are set, the 772 appends a new checksum as it updates the IOPB. 
If you want to disable the checksum, the Write Controller 
Parameters IOPB must have a valid checksum. 


AUTOMATIC STREAMING: RING BUFFERS 


A ring buffer is a multiple-cell data buffer; it comprises two, 
four, or eight cells depending on throughput requirements. Using 
ring buffers helps match disk systems with low transfer rates 
(400-20 kilobytes per second [KBS]) to the tape drive rate so that 
the tape drive always operates in streaming mode. Ring buffers 
reduce the total data transfer time even at rates lower than 20 
KBS; the same time savings occur when transferring data from the 
tape drive back to the disk system (see Figure 8-2). 
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8.9 AUTOMATIC STREAMING: RING BUFFERS (continued) 
When using ring buffers: 


1. Only empty a buffer when it is full. 

2. Only fill a buffer when it is empty. 

3. During repositioning or stopping, all buffers must be full 
before the next tape operation. 


During a data transfer to tape, if the input rate to the buffers is 
lower than the output rate, the tape drive outruns the buffers. 
Therefore, fill all the buffers before the tape drive starts 
emptying them. Refill all the buffers while the tape drive is 
repositioning. 


When transferring data from tape to disk: 


1. Only empty a buffer when it is full. 

2. Only £111 a buffer when it is empty. 

3. During repositioning or stopping, all buffers must be empty 
before the next tape operation. 


| STREAMING 
TAPE DRIVE 


Figure 8-2. Disk to Tape Transfer Using Ring Buffers 
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8.10 


8.11 


INTERRUPT AT END OF CHAIN 


IEC prevents the 772 from interrupting after completing each IOPB 
in a chain. The 772 executes the entire chain and then interrupts 
(using the interrupt level and vector from the first IOPB in the 
Chain). If a non-retryable error occurs in the middle of a chain, 
the 772 returns the remaining IOPBs at the same interrupt vector 
and level as Aborted by Error. ‘The controller completes all the 
IOPBS and interrupts once. It may complete IOPBs at different 
interrupt levels and vectors normally. When IEC is clear, the 772 
interrupts after completing each IOPB (providing the interrupt 
level is not zero). 


RELEASE ON REQUEST 


When ROR is enabled, the 772 tests the VMEbus between each throttle 
for other pending bus requests. If another request is pending, the 
772 releases the bus. If there are no bus requests, the 772 
remains bus master. The throttle value determines how often the 
772 tests the bus. Lower throttle values slow down the DMA; higher 
throttle values cause the 772 to test the bus less frequently. 
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10.0 GENERAL 


This section describes the 772 tape drive interface. 


SECTION 10: 


10.1 PERTEC INTERFACE SIGNALS 


The 772 supports the industry standard Pertec-formatted Interface. 
Signal mnemonics may differ from one manufacturer to the next, but 
typically the function of the Signal remains the same. 
section defines a matrix of signals. 


DRIVE INTERFACE 


interface specification for further explanation. 


Name Cable 
FBY Pl 
LWD Pl 
WD4 Pl 
GO Pl 
WDO Pl 
WDL Pl 
SPARE PL 
LOL PL 
REV Pl 
REW Pl 
WDP Pl 
WD7 Pl 
WD3 Pl 
WD6 Pl 
WD2 Pl 
WD5 Pl 
WRI Pl 
LGAP Pl 
EDIT Pl 
ERASE Pl 
WEM Pl 
THR Pl 
TADO Pl 
RD2 Pl 
— RD3 Pl 
RDP P2 
RDO P2 
RD1 P2 
LDP P2 
RD4 P2 
RD7 P2 
RD6 P2 
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Signal Ground Description 


Pin Pin 
2 1 
4 3 
6 5 
8 7 
10 9 
12 11 
14 13 
16 15 
18 17 
20 19 
22 21 
24 23 
26 25 
28 2] 
30 29 
32 31 
34 33 
36 35 
38 37 
40 39 
42 4) 
44 43 
46 45 
48 47 
50 49 
1 5 
2 5 
3 be) 
4 5 
6 5 
8 7 
10 9 

106 


Formatter Busy 
Last Word 

Write Data 4 
Initiate Command 
Write Data 0 (MSB) 
Write Data l 
Reserved 

Load On-line 
Reverse/Forward 
Rewind 

Write Data Parity 
Write Data 7 
Write Data 3 
Write Data 6 
Write Data 2 
Write Data 5 
Write/Read 

Long Gap 

Edit 

Erase 

Write File Mark 
High Clip 
Transport Address 
Read Data 2 

Read Data 3 

Read Data P 

Read Data 0 (MSB) 
Read Data l 

Load Point 

Read Data 4 

Read Data 7 

Read Data 6 


KMKRKKMKMKRKR KEK KER KR KKK KKK RRR RRR KKK KKK KK 


This sub- 
Consult the manufacturer's 


Used By 772 
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10.1 PERTEC INTERFACE SIGNALS (continued) 
Name Cable Signal Ground Description Used By 772 
Pin Pin 
HER P2 12 11 Hard Error Y 
FMK P2 14 13 File Mark Y 
ID P2 16 15 PE ID Burst Y 
FEN P2 18 17 Formatter Enable Y 
RD5 P2 20 19 Read Data 5 Y 
EOT P2 22 21 End of Tape Y 
OFL P2 24 23 Off-line/Unload Y 
GCR P2 26 25 Density Status y 
RDY P2 28 2] Ready ¥ 
RWD P2 30 29 Rewinding Y 
FPT P2 32 31 File—protect Y 
RSTR P2 34 33 Read Strobe Y 
WSTR P2 36 35 Write Strobe Y 
DBY P2 38 37 Data Busy Y 
HSPD P2 40 39 Speed Y 
CER P2 42 4l Corrected Error Y 
ONL P2 44 43 On-line Y 
TAD] P2 46 45 Transport Address 1 Y 
FAD =—séié@ 48 47 Formatter Address Y 
HISP P2 50 49 High Speed Select Y 
10.2 SPECIAL SIGNAL DEFINITIONS 


Certain manufacturers define tape interface signals differently; 
this subsection lists these special definitions. (Refer directly 
to your drive manual for more information.) 


Connector Pin--—-> Pl: 14 16 36 44 2: 16 26 
CDC 92181 — LOL LGAP — PEID -- 
92185 — LOL LGAP THRILL PEID GCR 
Cipher F880 - -—- — — PEID — 
M890 _-_ - —- = PEID — 
M990 —_ —_ — — PEID — 
Fujitsu 2242 — — Gap — PEID GCR 
Kennedy 9400 —_ LOL LGAP THRILL ID/CCG NRZ 
9600 — lio, — LGAP ID/COG NRZ 
Megatape MT500 = = — —_ ID — 
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10.2 SPECIAL SIGNAL DEFINITIONS (continued) 


Connector Pin ---> Pl: 14 16 36 44 P2: 16 26 


Pertec FS1000 SGL LOL THR) THR2 PEID NRZ 
FS2000 FAULT LOL j#HIDEN LGAP PEID GCR/DIAG 
STC 2920 — lio. — — PEID GCR 
Telex Shamrock _— —_— DEN — PEID GCR 
Thorn 9600 DGM IO. HIDEN DBLGAP ID/CCG NRZ 
9900 DGM LOL HIDEN DBLGAP PEID NRZ 


10.3 VMEbus INTERFACE SIGNALS 


Used By 
Mnemonic Conn. Pin 7712. Description 
AOl PIA 30 Y 
AO2 P1lA 29 Y 
A03 P1A 28 Y 
A04 PIA 27 Y 
A05 PIA 26 Y 
A06 PIA 25 Y 
AQ7 P1A 24 Y 
AO08 PLC 30 Y 
A09 PLC 29 Y 
AlLO P1C 28 y 
All P1C 27 Y 
Al2 PLC 26 Y 
Al3 P1C 25 Y 
Al4 PLC 24 Y 
AlL5 P1C 23 Y Address Bus 
Al6 PLC 22 Y 
Al7 P1C 21 Y 
Al8 PLC 20 Y 
Al9 ~ PLC 19 Y 
A20 P1C 18 Y 
A21 P1C 17 Y 
A22 P1C 16 Y 
A23 P1C 15 Y 
A24 P2B 4 Y 
A25 P2B 5 Y 
A26 P2B 6 Y 
A27 P2B 7 Y 
A28 P2B 8 Y 
A29 P2B 9 Y 
A30 P2B 10 Y 
A31 P2B 11 Y 
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10.3 VMEbus INTERFACE SIGNALS (continued) 


Used By : 
AMO P1B 16 Y 
AML P1B 17 Y | 
AM2 P1B 18 Y Address Modifier 
AMS P1B 19 Y 
AM4 PIA 23 Y 
AM5 PLC 14 Y 
DOO PIA 1 Y 
DO1 PIA 2 Y 
DO2 PIA 3 Y 
DO3 P1lA 4 Y 
D04 P1lA 5 Y 
DO5 PlA 6 Y 
D06 PlA 7 Y 
DO7 P1lA 8 Y 
DOs P1C 1 Y 
DO9 P1C 2 Y 
D1O PLC 3 Y 
Dll P1C 4 Y 
D12 PIC 5 Y 
D13 P1C 6 Y 
D14 PLC 7 Y 
D1L5 P1C 8 Y Data Bus 
D16 P2B 14 Y 
DL7 P2B 15 Y 
D18 P2B 16 Y 
D119 P2B 17 Y 
D20 P2B 18 Y 
D21 P2B 19 Y 
D22 P2B 20 Y 
D23 P2B 21 Y 
D24 P2B 23 Y 
D25 P2B 24 Y 
D26 P2B 25 Y 
D27 P2B 26 Y 
D28 P2B 27 Y 
D29 P2B 28 Y 
D30 P2B 29 Y 
D31 P2B 30 Y 
Strobes 
As* P1LA 18 Y Address Strobe 
pso* PLA 13 Y Data Strobe Zero 
ps1* PLA 12 Y Data Strobe One 
DTACK* PLA 16 Y Data Transfer Acknowledge 
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10.3 


VMEbus INTERFACE SIGNALS (continued) 


Mnemonic §§ Conn (Pin 


Clocks 
SERCLK P1B 21 
SYSCLK PIA 10 
DMA 
BBSY* PIB 1 
BCLR* PIB 2 
BERR* P1C 11 
BGOIN* PIB 4 
BGLIN* PLB 6 
BG2 IN* PIB 8 
BG3 IN* PIB 10 
BGOOUT* P1B 5 
BGLOUT* PLB 7 
BG20UT* P1B 9 
BG30UT* PIB 11 
BRO* PLB 12 
BR1* PIB 13 
BR2* P1B 14 
BR3* PIB 15 
Interrupts 
TRQ1* PIB 30 
IRQ2* PIB 29 
IRQ3* P1B 28 
TRO4* PIB 27 
TRO5* P1B 26 
IRQ6* PIB 25 
IRQ7* PIB 24 
 TACK* PIA 20 
TACKIN* PIA 21 
TACKOUT* PIA 22 
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Used By 
T712. 
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RKKKR KKK KR RK KK KR K 


KmRKK KKK KK KK 
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, oti 


Serial Clock 
System Clock 


Bus Busy 
Bus Clear 
Bus Error 


Bus Grant In 


Bus Grant Out 


Bus Request 


Interrupt Request Levels 


Interrupt Acknowledge 
Interrupt Acknowledge In 
Interrupt Acknowledge Out 
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10.3 


VMEbus INTERFACE SIGNALS (continued) 


Mnemonic § Conn 


Miscellaneous 


ACFAIL* 
LWORD* 
RESERVED 
SERDAT* 
SYSRESET* 
WRITE* 


PLB 
PLC 
P2B 
PIB 
PLC 
PIA 


PIA, PIB, PLC 
P2B 
P1B 
P1C 
PIA 
PIA 
PIB 
P2B 
PIC 
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Pin 


32 
1,13,32. 
31 
31 
31 


9,11,15,17,19 


20,23 
2,12,22,31 
9 


lil 


KKRaAaaKK 


KKRKK Za aKK 


AC Failure 
Longword 
Reserved 
Serial Data 
System Reset 
Write 


+5 VDC 

+5 VDC 

+5 VDC Standby 
+12 VDC 

-12 VDC 

Signal Ground 
Signal Ground 
Signal Ground 


Signal Ground 
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